/* ==========================================================================
   Mackximal Digital Atelier – Global Styles
   Design System: "No-Line Rule", Tonal Layering, Glassmorphism
   ========================================================================== */

/* --- Material Symbols Icon Font --- */
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;700;800;900&family=Public+Sans:wght@300;400;500;600&display=swap');

.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
}

/* --- Design System Tokens (mirrored from theme.json) --- */
:root {
  --mck-primary:                  #0e2b46;
  --mck-primary-container:        #27415d;
  --mck-on-primary:               #ffffff;
  --mck-on-primary-container:     #93adce;
  --mck-secondary:                #6b5c4a;
  --mck-secondary-container:      #f1dcc5;
  --mck-on-secondary-container:   #6f604e;
  --mck-secondary-fixed:          #f4dfc8;
  --mck-on-secondary-fixed:       #241a0c;
  --mck-on-secondary-fixed-dim:   #524434;
  --mck-surface:                  #f9f9f9;
  --mck-surface-container-lowest: #ffffff;
  --mck-surface-container-low:    #f3f3f3;
  --mck-surface-container:        #eeeeee;
  --mck-surface-container-high:   #e8e8e8;
  --mck-surface-container-highest:#e2e2e2;
  --mck-on-surface:               #1a1c1c;
  --mck-on-surface-variant:       #43474d;
  --mck-outline:                  #73777e;
  --mck-outline-variant:          #c3c6ce;

  /* Signature Gradient – "soul" of primary */
  --mck-signature-gradient: linear-gradient(135deg, #0e2b46 0%, #27415d 100%);

  /* Glassmorphism */
  --mck-glass-bg: rgba(255, 255, 255, 0.80);
  --mck-glass-blur: blur(20px);

  /* Ambient Shadows (not "cheap" drop shadows) */
  --mck-shadow-ambient:  0 24px 40px rgba(26, 28, 28, 0.06);
  --mck-shadow-float:    0 8px 24px rgba(26, 28, 28, 0.08);
  --mck-shadow-elevated: 0 2px 8px rgba(26, 28, 28, 0.05);

  /* Border Radius */
  --mck-radius-sm:   0.125rem;
  --mck-radius-md:   0.25rem;
  --mck-radius-lg:   0.5rem;
  --mck-radius-xl:   0.75rem;
  --mck-radius-2xl:  1rem;
  --mck-radius-3xl:  1.5rem;
  --mck-radius-full: 9999px;
}

/* ==========================================================================
   BASE RESET
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; -webkit-font-smoothing: antialiased; }
img, video { max-width: 100%; height: auto; display: block; }

/* ==========================================================================
   NAVIGATION – Glassmorphism
   ========================================================================== */
.mck-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--mck-glass-bg);
  backdrop-filter: var(--mck-glass-blur);
  -webkit-backdrop-filter: var(--mck-glass-blur);
  border-bottom: 1px solid rgba(195, 198, 206, 0.15); /* Ghost border */
}

.mck-nav__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  max-width: 1280px;
  margin: 0 auto;
}

.mck-nav__logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
}

.mck-nav__logo-text {
  font-family: Inter, sans-serif;
  font-weight: 900;
  font-size: 1.5rem;
  letter-spacing: -0.04em;
  color: var(--mck-primary);
  line-height: 1;
}

.mck-nav__links {
  display: flex;
  align-items: center;
  gap: 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mck-nav__links a {
  font-family: 'Public Sans', sans-serif;
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--mck-on-surface-variant);
  text-decoration: none;
  transition: color 0.2s;
}
.mck-nav__links a:hover,
.mck-nav__links a[aria-current="page"] {
  color: var(--mck-primary);
  font-weight: 700;
}

/* ==========================================================================
   BUTTONS – "Precision Tools"
   ========================================================================== */

/* Primary – Signature Gradient */
.wp-block-button.is-style-primary .wp-block-button__link,
.mck-btn-primary {
  background: var(--mck-signature-gradient) !important;
  color: var(--mck-on-primary) !important;
  border: none !important;
  border-radius: var(--mck-radius-md) !important;
  font-family: Inter, sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em;
  box-shadow: var(--mck-shadow-float);
  transition: opacity 0.2s, transform 0.15s;
  padding: 1rem 2.5rem !important;
}
.wp-block-button.is-style-primary .wp-block-button__link:hover,
.mck-btn-primary:hover {
  opacity: 0.92;
  transform: scale(0.99);
}

/* Secondary – Warm sandy */
.wp-block-button.is-style-secondary .wp-block-button__link,
.mck-btn-secondary {
  background: var(--mck-surface-container-high) !important;
  color: var(--mck-primary) !important;
  border: none !important;
  border-radius: var(--mck-radius-md) !important;
  font-family: Inter, sans-serif !important;
  font-weight: 700 !important;
  padding: 1rem 2.5rem !important;
  transition: background 0.2s;
}
.wp-block-button.is-style-secondary .wp-block-button__link:hover {
  background: var(--mck-surface-container-highest) !important;
}

/* Ghost */
.wp-block-button.is-style-ghost .wp-block-button__link {
  background: transparent !important;
  color: var(--mck-primary) !important;
  border: 1.5px solid var(--mck-primary) !important;
  border-radius: var(--mck-radius-md) !important;
  font-family: Inter, sans-serif !important;
  font-weight: 700 !important;
  padding: 0.875rem 2.25rem !important;
}

/* ==========================================================================
   SECTION WRAPPERS
   ========================================================================== */

/* Content-width inner wrapper */
.mck-section {
  padding-block: 6rem;
  padding-inline: 2rem;
}
.mck-section__inner {
  max-width: 1280px;
  margin-inline: auto;
}

/* Surface alternation (No-Line Rule) */
.mck-surface-base     { background: var(--mck-surface); }
.mck-surface-low      { background: var(--mck-surface-container-low); }
.mck-surface-mid      { background: var(--mck-surface-container); }
.mck-surface-high     { background: var(--mck-surface-container-high); }
.mck-surface-primary  { background: var(--mck-primary); color: var(--mck-on-primary); }

/* ==========================================================================
   CARDS – Atelier Cards (no heavy shadow, ghost border only)
   ========================================================================== */
.mck-card {
  background: var(--mck-surface-container-lowest);
  border-radius: var(--mck-radius-2xl);
  border: 1px solid rgba(195, 198, 206, 0.15); /* Ghost border 15% opacity */
  padding: 2.5rem;
  box-shadow: var(--mck-shadow-elevated);
}

.mck-card--dark {
  background: var(--mck-primary);
  color: var(--mck-on-primary);
  border: none;
}

.mck-card--warm {
  background: var(--mck-secondary-container);
  color: var(--mck-on-secondary-container);
  border: none;
}

/* ==========================================================================
   BENTO GRID
   ========================================================================== */
.mck-bento {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .mck-bento { grid-template-columns: repeat(3, 1fr); }
  .mck-bento__wide { grid-column: span 2; }
  .mck-bento__full { grid-column: span 3; }
}

/* ==========================================================================
   CHIPS – "Interactive Chips" from Design System
   ========================================================================== */
.mck-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  background: var(--mck-secondary-fixed);
  color: var(--mck-on-secondary-fixed-dim);
  font-family: Inter, sans-serif;
  font-weight: 700;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.25rem 0.75rem;
  border-radius: var(--mck-radius-md);
  line-height: 1.5;
}

.mck-chip--primary {
  background: rgba(14, 43, 70, 0.08);
  color: var(--mck-primary);
}

/* ==========================================================================
   TYPOGRAPHY HELPERS
   ========================================================================== */
.mck-display {
  font-family: Inter, sans-serif;
  font-weight: 900;
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--mck-primary);
}

.mck-headline {
  font-family: Inter, sans-serif;
  font-weight: 800;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--mck-primary);
}

.mck-subline {
  font-family: 'Public Sans', sans-serif;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  color: var(--mck-on-surface-variant);
  line-height: 1.65;
}

.mck-label {
  font-family: Inter, sans-serif;
  font-weight: 700;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mck-secondary);
}

/* ==========================================================================
   HERO LAYOUT
   ========================================================================== */
.mck-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
  align-items: center;
  padding-block: 8rem 5rem;
  padding-inline: 2rem;
  max-width: 1280px;
  margin-inline: auto;
}

@media (min-width: 1024px) {
  .mck-hero { grid-template-columns: 7fr 5fr; }
}

/* ==========================================================================
   WORKFLOW STEPS
   ========================================================================== */
.mck-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  position: relative;
}

@media (min-width: 768px) {
  .mck-steps { grid-template-columns: repeat(3, 1fr); }
  .mck-steps::before {
    content: '';
    position: absolute;
    top: 2rem;
    left: 10%;
    right: 10%;
    height: 1px;
    border-top: 1px dashed rgba(147, 173, 206, 0.4);
    pointer-events: none;
  }
}

.mck-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

.mck-step__icon {
  width: 4rem;
  height: 4rem;
  border-radius: var(--mck-radius-full);
  background: var(--mck-on-primary);
  color: var(--mck-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  box-shadow: var(--mck-shadow-float);
  font-size: 1.75rem;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.mck-footer {
  background: var(--mck-surface-container-low);
  padding-block: 4rem;
  padding-inline: 2rem;
  border-top: 1px solid rgba(195, 198, 206, 0.2);
}

.mck-footer__inner {
  max-width: 1280px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}

@media (min-width: 768px) {
  .mck-footer__inner { grid-template-columns: 2fr 1fr 1fr 1fr; }
}

.mck-footer__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.mck-footer__links a {
  font-size: 0.875rem;
  color: var(--mck-on-surface-variant);
  text-decoration: none;
  transition: color 0.2s;
}
.mck-footer__links a:hover { color: var(--mck-primary); }

.mck-footer__bottom {
  max-width: 1280px;
  margin-inline: auto;
  padding-top: 2rem;
  border-top: 1px solid rgba(195, 198, 206, 0.15);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

/* ==========================================================================
   FLOATING QUOTE CARD (from Hero)
   ========================================================================== */
.mck-float-card {
  position: absolute;
  background: var(--mck-surface-container-lowest);
  border-radius: var(--mck-radius-xl);
  padding: 2rem;
  box-shadow: 0 20px 60px rgba(26, 28, 28, 0.12);
  max-width: 280px;
  bottom: -1.5rem;
  left: -1.5rem;
}

/* ==========================================================================
   WORDPRESS BLOCK OVERRIDES
   ========================================================================== */

/* Remove default block padding from site */
.wp-site-blocks { padding: 0 !important; }

/* Full-width sections */
.alignfull {
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  width: 100vw !important;
  max-width: 100vw !important;
}

/* Navigation block */
.wp-block-navigation {
  gap: 2rem;
}
.wp-block-navigation-item__content {
  font-family: 'Public Sans', sans-serif;
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--mck-on-surface-variant) !important;
  text-decoration: none;
  transition: color 0.2s;
  padding: 0 !important;
}
.wp-block-navigation-item__content:hover {
  color: var(--mck-primary) !important;
}
.current-menu-item .wp-block-navigation-item__content {
  color: var(--mck-primary) !important;
  font-weight: 700;
}

/* Separator */
.wp-block-separator {
  border: none;
  height: 1px;
  background: rgba(195, 198, 206, 0.3);
  margin: 0;
}

/* Cover block */
.wp-block-cover { min-height: 500px; }

/* Image */
.wp-block-image img {
  border-radius: var(--mck-radius-2xl);
}

/* Columns – remove default gap */
.wp-block-columns { gap: 1.5rem; }

/* Quote */
.wp-block-quote {
  border-left: none;
  padding: 0;
  font-family: Inter, sans-serif;
  font-style: italic;
  font-weight: 800;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  line-height: 1.2;
  color: inherit;
}
.wp-block-quote cite {
  font-style: normal;
  font-family: 'Public Sans', sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  display: block;
  margin-top: 1.5rem;
}

/* ==========================================================================
   MOBILE
   ========================================================================== */
@media (max-width: 767px) {
  .mck-section { padding-block: 4rem; padding-inline: 1.25rem; }
  .mck-hero { padding-block: 6rem 3rem; padding-inline: 1.25rem; }
  .mck-card { padding: 1.75rem; }
  .mck-nav__links { display: none; }
  .mck-float-card { display: none; }
}

/* ==========================================================================
   MOBILE MENU TOGGLE
   ========================================================================== */
.mck-nav__toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  color: var(--mck-primary);
}
@media (max-width: 767px) {
  .mck-nav__toggle { display: flex; align-items: center; justify-content: center; }
}

.mck-nav__mobile {
  display: none;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem 2rem;
  background: var(--mck-surface-container-lowest);
  border-top: 1px solid rgba(195,198,206,0.15);
}
.mck-nav__mobile.is-open { display: flex; }
.mck-nav__mobile a {
  font-family: 'Public Sans', sans-serif;
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--mck-on-surface);
  text-decoration: none;
  padding-block: 0.5rem;
}
