/*
Theme Name: DigiVibe Savora
Author: DigiVibe
Description: Savora theme
Version: 1.0
Text Domain: digivibe-savora
*/

/*
Theme Name: DigiVibe Savora
*/

/* =========================================================
SECTION: TOKENS
========================================================= */

:root {
  /* COLORS */
  --dv-color-primary: #0b3a52;
  --dv-color-primary-hover: #13506f;

  --dv-color-surface: #ffffff;
  --dv-color-surface-muted: #f4f7f9;

  --dv-color-text: #0b1f2a;
  --dv-color-text-muted: #5b6b73;
  --dv-color-text-secondary: rgb(231, 180, 13);

  --dv-color-border: #d9e2e7;

  --dv-color-success: #1d7f4e;
  --dv-color-warning: #d68a00;
  --dv-color-danger: #8b0000;

  /* SHADOWS */
  --dv-shadow-card: 0 10px 30px rgba(0, 0, 0, 0.12);
  --dv-shadow-button: 0 10px 22px rgba(0, 0, 0, 0.18);

  /* RADIUS */
  --dv-radius-sm: 0.5rem;
  --dv-radius-md: 1rem;
  --dv-radius-lg: 1.5rem;
  --dv-radius-pill: 999px;

  /* SPACING */
  --dv-space-1: 0.25rem;
  --dv-space-2: 0.5rem;
  --dv-space-3: 0.75rem;
  --dv-space-4: 1rem;
  --dv-space-5: 1.5rem;
  --dv-space-6: 2rem;
  --dv-space-7: 3rem;

  /* TYPOGRAPHY */
  --dv-font-body:
    ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --dv-font-accent: Georgia, serif;
}

/* =========================================================
SECTION: BASE
========================================================= */

html {
  scroll-behavior: smooth;
}

body {
  color: var(--dv-color-text, #0b1f2a);
  font-family: var(--dv-font-body);
  background: var(--dv-color-surface-muted, #f4f7f9);
  line-height: 1.6;
}

/* =========================================================
SECTION: TYPOGRAPHY
========================================================= */

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  color: var(--dv-color-text, #0b1f2a);
  line-height: 1.2;
}

p {
  margin-top: 0;
}

.dv-text-muted {
  color: var(--dv-color-text-muted, #5b6b73);
}

.dv-text-accent {
  font-family: var(--dv-font-accent);
}

/* =========================================================
SECTION: BUTTONS
========================================================= */

.dv-button,
.wp-element-button {
  appearance: none;
  box-sizing: border-box;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: auto;
  min-height: 3rem;
  padding: 0.85rem 1.5rem;

  border: 0;
  border-radius: var(--dv-radius-pill, 999px);

  background: var(--dv-color-primary, #0b3a52);
  color: #ffffff;

  font: inherit;
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none;

  cursor: pointer;

  box-shadow: var(--dv-shadow-button);

  transition:
    background 0.2s ease,
    transform 0.2s ease,
    opacity 0.2s ease;
}

.dv-button:hover:not(.dv-button--secondary):not(.dv-button--danger):not(
    .dv-button--warning
  ):not(.dv-button--success),
.wp-element-button:hover {
  background: var(--dv-color-primary-hover, #13506f);
  color: #ffffff;
  text-decoration: none;
  transform: translateY(-1px);
}

.dv-button:disabled,
.wp-element-button:disabled {
  opacity: 0.65;
  cursor: wait;
}

/* =========================================================
SECTION: BUTTON VARIANTS
========================================================= */

.dv-button--secondary,
a.dv-button--secondary {
  background: var(--dv-color-text-secondary, black);
  color: #000000;
}

.dv-button--secondary:hover,
a.dv-button--secondary:hover {
  background: var(--dv-color-text-secondary, black);
  color: #000000;
}

.dv-button--danger,
a.dv-button--danger {
  background: var(--dv-color-danger, #8b0000);
  color: #ffffff;
}

.dv-button--danger:hover,
a.dv-button--danger:hover {
  background: #b30000;
  color: #ffffff;
}

.dv-button--warning,
a.dv-button--warning {
  background: var(--dv-color-warning, #d68a00);
  color: #ffffff;
}

.dv-button--warning:hover,
a.dv-button--warning:hover {
  background: #f09b00;
  color: #ffffff;
}

.dv-button--success,
a.dv-button--success {
  background: var(--dv-color-success, #1d7f4e);
  color: #ffffff;
}

.dv-button--success:hover,
a.dv-button--success:hover {
  background: #23945b;
  color: #ffffff;
}

/* =========================================================
SECTION: CARDS
========================================================= */

.dv-card {
  padding: var(--dv-space-5, 1.5rem);
  border-radius: var(--dv-radius-lg, 1.5rem);

  background: var(--dv-color-surface, #ffffff);

  box-shadow: var(--dv-shadow-card);
}

.dv-card--muted {
  background: var(--dv-color-surface-muted, #f4f7f9);
}

.dv-card--wide {
  width: 100%;
}

/* =========================================================
SECTION: FORMS
========================================================= */

input,
textarea,
select {
  width: 100%;
  padding: 0.85rem 1rem;

  border: 1px solid var(--dv-color-border, #d9e2e7);
  border-radius: var(--dv-radius-md, 1rem);

  background: #ffffff;
  color: var(--dv-color-text, #0b1f2a);

  font: inherit;
}

input:focus,
textarea:focus,
select:focus {
  outline: 2px solid rgba(11, 58, 82, 0.2);
  border-color: var(--dv-color-primary, #0b3a52);
}

/* =========================================================
SECTION: ALERTS
========================================================= */

.dv-alert {
  padding: 1rem 1.25rem;
  border-radius: var(--dv-radius-md, 1rem);
  font-weight: 600;
}

.dv-alert--success {
  background: rgba(29, 127, 78, 0.12);
  color: var(--dv-color-success, #1d7f4e);
}

.dv-alert--warning {
  background: rgba(214, 138, 0, 0.12);
  color: var(--dv-color-warning, #d68a00);
}

.dv-alert--danger {
  background: rgba(139, 0, 0, 0.12);
  color: var(--dv-color-danger, #8b0000);
}

/* =========================================================
SECTION: LAYOUT
========================================================= */

.dv-container {
  width: min(100%, 1200px);
  margin-inline: auto;
  padding-inline: 1.5rem;
}

.dv-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.dv-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.dv-section {
  margin-block: 4rem;
}

/* =========================================================
SECTION: header
========================================================= */

header.wp-block-template-part {
  padding: 1rem 1.5rem;
  margin-top: 0;
  margin-bottom: 0;

  background: var(--dv-color-primary, #0b3a52);
  color: #ffffff;
}

header.wp-block-template-part a {
  color: #ffffff;
  text-decoration: underline;
}

.wp-block-post-content {
  margin-top: 0;
}

/* =========================================================
SECTION: FOOTER
========================================================= */

footer.wp-block-template-part {
  margin-top: 4rem;
  padding: 2rem 1.5rem;
  background: var(--dv-color-primary, #0b3a52);
  color: #ffffff;
}

.dv-br-footer {
  background: var(--dv-color-primary, #0b3a52) !important;
}

footer.wp-block-template-part a {
  color: #ffffff;
  text-decoration: underline;
}

footer.wp-block-template-part p {
  margin-bottom: 0;
}

/* =========================================================
SECTION: UTILITIES
========================================================= */

.dv-hidden {
  display: none !important;
}

.dv-center {
  text-align: center;
}

.dv-flex {
  display: flex;
}

.dv-flex-wrap {
  flex-wrap: wrap;
}

.dv-gap-md {
  gap: 1rem;
}

/* =========================================================
SECTION: WORDPRESS OVERRIDES
========================================================= */

.wp-site-blocks {
  min-height: 100vh;
}

:where(.wp-site-blocks *) {
  box-sizing: border-box;
}

/* =========================================================
SECTION: RESPONSIVE
========================================================= */

@media (max-width: 900px) {
  .dv-grid-2,
  .dv-grid-3 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .dv-container {
    padding-inline: 1rem;
  }

  .dv-section {
    margin-block: 2.5rem;
  }
}
