/* ============================================================
   BRAINSDR.COM — Tallahassee Neurology Associates
   Art direction: Deep navy + teal + aged parchment + Renaissance anatomical art
   Typography: Cormorant Garamond (display) + Inter (body)
   ============================================================ */

/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root {
  /* Type scale */
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.5rem);
  --text-3xl:  clamp(2.5rem,   1rem    + 4vw,    5rem);
  --text-hero: clamp(3rem,     0.5rem  + 7vw,    8rem);

  /* Spacing */
  --space-1: 0.25rem; --space-2: 0.5rem;  --space-3: 0.75rem;
  --space-4: 1rem;    --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem;    --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem;   --space-20: 5rem;   --space-24: 6rem;
  --space-32: 8rem;

  /* Navy/Teal/Parchment palette — light mode */
  --color-bg:               #f5f3ee;
  --color-surface:          #faf8f4;
  --color-surface-2:        #ffffff;
  --color-surface-offset:   #ece9e2;
  --color-surface-offset-2: #e4e0d8;
  --color-divider:          #d8d4ca;
  --color-border:           #cdc9be;

  --color-text:         #1a1c24;
  --color-text-muted:   #6b6e7a;
  --color-text-faint:   #b0b3bc;
  --color-text-inverse: #f5f3ee;

  /* Navy primary */
  --color-navy:         #0d1b3e;
  --color-navy-mid:     #162248;
  --color-navy-light:   #1e2f5c;

  /* Teal accent */
  --color-primary:       #01696f;
  --color-primary-hover: #0c4e54;
  --color-primary-light: #e0edec;

  /* Parchment / sepia for art panels */
  --color-parchment:     #e8dfca;
  --color-sepia:         #c4a97a;

  /* Radius, transition, shadow */
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.875rem;
  --radius-xl: 1.25rem;
  --transition: 200ms cubic-bezier(0.16, 1, 0.3, 1);
  --shadow-sm: 0 1px 3px rgba(13,27,62,0.08);
  --shadow-md: 0 4px 16px rgba(13,27,62,0.10);
  --shadow-lg: 0 12px 40px rgba(13,27,62,0.15);

  /* Widths */
  --content-narrow:  680px;
  --content-default: 1000px;
  --content-wide:    1240px;

  /* Fonts */
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* Dark mode */
[data-theme="dark"] {
  --color-bg:               #0d1018;
  --color-surface:          #121520;
  --color-surface-2:        #161a28;
  --color-surface-offset:   #1a1e2e;
  --color-surface-offset-2: #1e2436;
  --color-divider:          #252b3d;
  --color-border:           #2e3550;
  --color-text:             #dde0ea;
  --color-text-muted:       #7c82a0;
  --color-text-faint:       #4a5070;
  --color-text-inverse:     #0d1018;
  --color-navy:             #0f1535;
  --color-navy-mid:         #172040;
  --color-navy-light:       #1e2d58;
  --color-primary:          #4fa8b0;
  --color-primary-hover:    #3d8890;
  --color-primary-light:    #1a2d30;
  --color-parchment:        #2a2518;
  --color-sepia:            #7a6340;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.5);
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg:#0d1018;--color-surface:#121520;--color-surface-2:#161a28;
    --color-surface-offset:#1a1e2e;--color-surface-offset-2:#1e2436;
    --color-divider:#252b3d;--color-border:#2e3550;
    --color-text:#dde0ea;--color-text-muted:#7c82a0;--color-text-faint:#4a5070;
    --color-text-inverse:#0d1018;--color-navy:#0f1535;--color-navy-mid:#172040;
    --color-navy-light:#1e2d58;--color-primary:#4fa8b0;--color-primary-hover:#3d8890;
    --color-primary-light:#1a2d30;--color-parchment:#2a2518;--color-sepia:#7a6340;
  }
}

/* ── BASE RESET ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;scroll-padding-top:80px;}
body{min-height:100dvh;line-height:1.65;font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);}
img,svg{display:block;max-width:100%;height:auto;}
ul[role=list],ol[role=list]{list-style:none;}
input,button,textarea,select{font:inherit;color:inherit;}
h1,h2,h3,h4,h5,h6{text-wrap:balance;line-height:1.15;font-family:var(--font-display);}
p,li{text-wrap:pretty;max-width:72ch;}
::selection{background:color-mix(in oklab,var(--color-primary) 20%,transparent);color:var(--color-text);}
:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm);}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}}
a,button,[role=button]{transition:color var(--transition),background var(--transition),border-color var(--transition),box-shadow var(--transition),opacity var(--transition);}

/* ── LAYOUT CONTAINERS ──────────────────────────────────────── */
.container       {max-width:var(--content-default);margin-inline:auto;padding-inline:clamp(var(--space-4),4vw,var(--space-12));}
.container-wide  {max-width:var(--content-wide);  margin-inline:auto;padding-inline:clamp(var(--space-4),4vw,var(--space-12));}
.container-narrow{max-width:var(--content-narrow); margin-inline:auto;padding-inline:clamp(var(--space-4),4vw,var(--space-12));}

/* ── TYPOGRAPHY HELPERS ─────────────────────────────────────── */
.section-eyebrow{font-size:var(--text-xs);font-family:var(--font-body);font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-3);}
.section-header{text-align:center;margin-bottom:clamp(var(--space-10),4vw,var(--space-16));}
.section-header h2{font-size:var(--text-2xl);font-weight:400;color:var(--color-text);margin-bottom:var(--space-4);}
.section-header--light .section-eyebrow{color:rgba(255,255,255,0.7);}
.section-header--light h2{color:#fff;}
.section-header--light .section-intro{color:rgba(255,255,255,0.8);}
.section-intro{font-size:var(--text-base);color:var(--color-text-muted);max-width:58ch;margin-inline:auto;line-height:1.75;}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:0.75em 1.6em;border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-body);font-weight:500;letter-spacing:0.02em;text-decoration:none;cursor:pointer;border:1.5px solid transparent;white-space:nowrap;}
.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary);}
.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);}
.btn-outline{background:transparent;color:var(--color-text);border-color:var(--color-border);}
.btn-outline:hover{background:var(--color-surface-offset);border-color:var(--color-primary);}
.btn-lg{padding:0.9em 2em;font-size:var(--text-base);}

/* ── HEADER ─────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:100;background:color-mix(in oklab,var(--color-navy) 97%,transparent);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,0.06);}
.header-inner{max-width:var(--content-wide);margin-inline:auto;padding-inline:clamp(var(--space-4),4vw,var(--space-8));height:68px;display:flex;align-items:center;gap:var(--space-8);}
.logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;color:#fff;flex-shrink:0;}
.logo-text{display:flex;flex-direction:column;line-height:1.2;}
.logo-name{font-family:var(--font-display);font-size:var(--text-base);font-weight:500;color:#fff;letter-spacing:0.01em;}
.logo-sub{font-size:var(--text-xs);color:rgba(255,255,255,0.55);letter-spacing:0.08em;font-family:var(--font-body);}
.main-nav{flex:1;display:flex;justify-content:flex-end;}
.main-nav ul{display:flex;align-items:center;gap:var(--space-6);list-style:none;}
.main-nav a{color:rgba(255,255,255,0.75);text-decoration:none;font-size:var(--text-sm);font-weight:400;letter-spacing:0.01em;}
.main-nav a:hover{color:#fff;}
.main-nav .nav-cta{background:var(--color-primary);color:#fff;padding:0.5em 1.2em;border-radius:var(--radius-md);font-weight:500;}
.main-nav .nav-cta:hover{background:var(--color-primary-hover);color:#fff;}
.main-nav .nav-refer{color:var(--color-primary);font-weight:600;border:1.5px solid var(--color-primary);padding:0.4em 1.1em;border-radius:var(--radius-md);transition:background .2s,color .2s;}
.main-nav .nav-refer:hover{background:var(--color-primary);color:#fff;}
.header-actions{display:flex;align-items:center;gap:var(--space-3);}
.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:rgba(255,255,255,0.6);background:transparent;border:none;cursor:pointer;}
.theme-toggle:hover{color:#fff;background:rgba(255,255,255,0.08);}
.mobile-menu-btn{display:none;flex-direction:column;gap:5px;width:36px;height:36px;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;}
.mobile-menu-btn span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,0.75);transition:transform var(--transition),opacity var(--transition);}
.mobile-nav{display:none;background:var(--color-navy);padding:var(--space-4) clamp(var(--space-4),4vw,var(--space-8)) var(--space-6);border-bottom:1px solid rgba(255,255,255,0.06);}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-1);}
.mobile-nav a{display:block;padding:var(--space-3) 0;color:rgba(255,255,255,0.8);text-decoration:none;font-size:var(--text-base);border-bottom:1px solid rgba(255,255,255,0.06);}
.mobile-nav .nav-cta{color:var(--color-primary);font-weight:500;border-bottom:none;}
@media(max-width:768px){
  .main-nav{display:none;}
  .mobile-menu-btn{display:flex;}
  .mobile-nav.open{display:block;}
}

/* ── HERO ───────────────────────────────────────────────────── */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;background:var(--color-navy);}
.hero-art{position:absolute;inset:0;z-index:0;}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:0.22;filter:sepia(60%) contrast(1.1);}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,27,62,0.92) 0%,rgba(13,27,62,0.7) 50%,rgba(1,105,111,0.3) 100%);}
.hero-content{position:relative;z-index:1;max-width:var(--content-wide);margin-inline:auto;padding:clamp(var(--space-16),8vw,var(--space-32)) clamp(var(--space-6),6vw,var(--space-16));padding-top:clamp(var(--space-20),10vw,var(--space-32));}
.hero-eyebrow{font-size:var(--text-xs);font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-5);}
.hero-heading{font-family:var(--font-display);font-size:var(--text-hero);font-weight:300;color:#fff;line-height:1.05;margin-bottom:var(--space-6);max-width:14ch;}
.hero-heading em{font-style:italic;color:color-mix(in oklab,var(--color-primary) 70%,#fff);}
.hero-sub{font-size:var(--text-base);color:rgba(255,255,255,0.72);max-width:50ch;line-height:1.75;margin-bottom:var(--space-10);}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4);}
.hero-actions .btn-outline{color:rgba(255,255,255,0.85);border-color:rgba(255,255,255,0.3);}
.hero-actions .btn-outline:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.6);}
.hero-scroll-indicator{position:absolute;bottom:var(--space-8);left:50%;transform:translateX(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:rgba(255,255,255,0.3);font-size:var(--text-xs);letter-spacing:0.1em;text-transform:uppercase;}
.scroll-dot{animation:scrollBounce 2s ease-in-out infinite;}
@keyframes scrollBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@media(max-width:600px){.hero-heading{font-size:clamp(2.5rem,10vw,4rem);}}

/* ── INTRO STRIP ────────────────────────────────────────────── */
.intro-strip{background:var(--color-navy-mid);border-bottom:1px solid rgba(255,255,255,0.06);padding:var(--space-8) 0;}
.intro-grid{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--space-6);}
.intro-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);text-align:center;padding:var(--space-2) var(--space-6);}
.stat-number{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;color:#fff;line-height:1;}
.stat-label{font-size:var(--text-xs);color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.1em;max-width:18ch;text-align:center;}
.intro-divider{width:1px;height:48px;background:rgba(255,255,255,0.12);}
@media(max-width:640px){.intro-divider{display:none;}.intro-grid{gap:var(--space-4);}}

/* ── SERVICES ───────────────────────────────────────────────── */
.services-section{position:relative;padding:clamp(var(--space-16),8vw,var(--space-32)) 0;overflow:hidden;}
.section-art-left{position:absolute;left:-60px;top:50%;transform:translateY(-50%);width:280px;opacity:0.06;filter:sepia(80%);pointer-events:none;}
.section-art-left img{width:100%;height:auto;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5);}
.service-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);}
.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--color-primary);}
.service-icon{width:44px;height:44px;margin-bottom:var(--space-4);color:var(--color-primary);flex-shrink:0;}
.service-icon svg{width:100%;height:100%;}
.service-card h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:var(--color-text);margin-bottom:var(--space-3);line-height:1.2;}
.service-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.7;}
.service-card--featured{border-color:color-mix(in oklab,var(--color-primary) 30%,var(--color-border));background:color-mix(in oklab,var(--color-primary) 4%,var(--color-surface));}
.service-badge{display:inline-block;margin-top:var(--space-4);padding:0.25em 0.75em;background:var(--color-primary-light);color:var(--color-primary);font-size:var(--text-xs);font-weight:600;letter-spacing:0.06em;text-transform:uppercase;border-radius:var(--radius-full);font-family:var(--font-body);}
[data-theme="dark"] .service-badge{background:var(--color-primary-light);color:var(--color-primary);}

/* ── ART DIVIDER ────────────────────────────────────────────── */
.art-divider{position:relative;height:320px;overflow:hidden;background:var(--color-navy);}
.art-divider-img{width:100%;height:100%;object-fit:cover;object-position:center 40%;opacity:0.18;filter:sepia(70%) contrast(1.2);}
.art-divider-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(13,27,62,0.7) 0%,rgba(13,27,62,0.5) 50%,rgba(13,27,62,0.7) 100%);}
.art-quote{text-align:center;padding:var(--space-6) var(--space-8);}
.art-quote p{font-family:var(--font-display);font-size:var(--text-xl);font-weight:300;font-style:italic;color:rgba(255,255,255,0.85);line-height:1.5;max-width:50ch;}

/* ── PROVIDERS ──────────────────────────────────────────────── */
.providers-section{position:relative;padding:clamp(var(--space-16),8vw,var(--space-32)) 0;background:var(--color-surface);overflow:hidden;}
.section-art-right{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:260px;opacity:0.05;filter:sepia(80%);pointer-events:none;}
.section-art-right img{width:100%;height:auto;}
.providers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--space-8);}
.provider-card{display:flex;gap:var(--space-6);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-sm);}
.provider-portrait{flex-shrink:0;width:120px;}
.provider-portrait-inner{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);}
.provider-placeholder{width:120px;height:140px;}
.provider-info{flex:1;}
.provider-info h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;margin-bottom:var(--space-1);}
.provider-title{font-size:var(--text-sm);color:var(--color-primary);font-weight:500;margin-bottom:var(--space-2);}
.provider-specialties{font-size:var(--text-xs);color:var(--color-text-faint);letter-spacing:0.04em;margin-bottom:var(--space-4);font-family:var(--font-body);}
.provider-bio{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.75;}
@media(max-width:520px){.provider-card{flex-direction:column;}.provider-portrait{width:80px;}.provider-placeholder{width:80px;height:94px;}}

/* ── APPOINTMENT ────────────────────────────────────────────── */
.appointment-section{padding:clamp(var(--space-16),8vw,var(--space-32)) 0;background:var(--color-navy);}
.appointment-section .section-eyebrow{color:rgba(255,255,255,0.55);}
.appointment-section h2{color:#fff;}
.appointment-section .section-intro{color:rgba(255,255,255,0.65);}
.appointment-form{background:var(--color-surface-2);border-radius:var(--radius-xl);padding:clamp(var(--space-8),4vw,var(--space-12));box-shadow:var(--shadow-lg);}
[data-theme="dark"] .appointment-form{background:var(--color-surface);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);}
@media(max-width:520px){.form-row{grid-template-columns:1fr;}}
.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4);}
.form-group--full{grid-column:1/-1;}
.form-group label{font-size:var(--text-sm);font-weight:500;color:var(--color-text);}
.form-group label span{color:var(--color-primary);}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.7em 0.9em;background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);transition:border-color var(--transition),box-shadow var(--transition);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in oklab,var(--color-primary) 15%,transparent);}
.form-group textarea{resize:vertical;min-height:80px;}
.form-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-6);}
.form-privacy{font-size:var(--text-xs);color:var(--color-text-faint);max-width:40ch;}
.form-success{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--color-primary-light);border-radius:var(--radius-lg);color:var(--color-primary);margin-top:var(--space-4);}
.form-success svg{flex-shrink:0;}
.form-success p{font-size:var(--text-sm);font-weight:500;}

/* ── LOCATION ───────────────────────────────────────────────── */
.location-section{padding:clamp(var(--space-16),8vw,var(--space-32)) 0;}
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(var(--space-8),4vw,var(--space-16));align-items:start;}
@media(max-width:768px){.location-grid{grid-template-columns:1fr;}}
.practice-address{font-style:normal;font-size:var(--text-base);line-height:1.7;margin-bottom:var(--space-4);color:var(--color-text);}
.location-phone{display:block;font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;color:var(--color-primary);text-decoration:none;margin-bottom:var(--space-8);}
.location-phone:hover{color:var(--color-primary-hover);}
.hours{margin-bottom:var(--space-8);}
.hours h3,.directions-block h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;margin-bottom:var(--space-4);color:var(--color-text);}
.hours-list{display:grid;grid-template-columns:auto 1fr;gap:var(--space-2) var(--space-6);}
.hours-list dt{font-size:var(--text-sm);font-weight:500;color:var(--color-text);}
.hours-list dd{font-size:var(--text-sm);color:var(--color-text-muted);}
.directions-block{margin-bottom:var(--space-8);}
.directions-list{display:flex;flex-direction:column;gap:var(--space-3);}
.directions-list li{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--space-1) var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;}
.directions-list li svg{flex-shrink:0;margin-top:3px;}
.directions-list li>span{flex:1;min-width:0;}
.directions-list svg{flex-shrink:0;margin-top:3px;color:var(--color-primary);}
.map-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);}
.location-map{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-md);}
.location-map iframe{display:block;}

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer{position:relative;background:var(--color-navy);color:rgba(255,255,255,0.7);overflow:hidden;padding-top:clamp(var(--space-16),8vw,var(--space-24));}
.footer-art{position:absolute;right:0;top:0;width:400px;height:100%;pointer-events:none;opacity:0.04;filter:sepia(100%);}
.footer-art img{width:100%;height:100%;object-fit:cover;object-position:left center;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(var(--space-6),3vw,var(--space-12));margin-bottom:var(--space-16);}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr;}}
.footer-brand .logo{color:rgba(255,255,255,0.9);margin-bottom:var(--space-4);}
.footer-brand .logo--footer .logo-name{font-size:var(--text-sm);}
.footer-tagline{font-size:var(--text-sm);color:rgba(255,255,255,0.45);max-width:30ch;line-height:1.7;}
.footer-col h4{font-family:var(--font-display);font-size:var(--text-base);font-weight:500;color:rgba(255,255,255,0.9);margin-bottom:var(--space-4);}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-2);}
.footer-col a{font-size:var(--text-sm);color:rgba(255,255,255,0.5);text-decoration:none;}
.footer-col a:hover{color:rgba(255,255,255,0.9);}
.footer-address{font-style:normal;font-size:var(--text-sm);color:rgba(255,255,255,0.5);line-height:1.7;margin-bottom:var(--space-3);}
.footer-phone{display:block;font-family:var(--font-display);font-size:var(--text-lg);color:rgba(255,255,255,0.8);text-decoration:none;margin-bottom:var(--space-2);}
.footer-hours{font-size:var(--text-xs);color:rgba(255,255,255,0.4);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding:var(--space-6) 0;display:flex;flex-direction:column;gap:var(--space-2);}
.footer-bottom p{font-size:var(--text-xs);color:rgba(255,255,255,0.35);}
.footer-disclaimer{font-size:var(--text-xs);color:rgba(255,255,255,0.25);font-style:italic;}

/* ── PRINT STYLES ───────────────────────────────────────────── */
@media print{
  .site-header,.hero-scroll-indicator,.mobile-menu-btn,.theme-toggle,.hero-actions,.map-actions .btn:not(:first-child),.site-footer .footer-art{display:none!important;}
  .hero{min-height:auto;padding:var(--space-8) 0;}
  .hero-img,.hero-overlay{display:none;}
  .hero-content{color:#000;}
  .hero-heading,.hero-sub{color:#000;}
  body{color:#000;background:#fff;}
  .appointment-section,.art-divider{background:#fff!important;}
}

/* ── Referral Banner Section ─────────────────────────────────── */
.referral-banner-section {
  padding: clamp(48px, 7vw, 80px) 0;
  background: linear-gradient(135deg, #0f2d52 0%, #1a4a7a 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.referral-banner-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;
  pointer-events: none;
}
.referral-banner-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 36px;
  align-items: center;
  position: relative;
}
.referral-banner-icon {
  color: rgba(255,255,255,0.25);
  flex-shrink: 0;
}
.referral-banner-eyebrow {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #5eead4;
  margin-bottom: 8px;
}
.referral-banner-text h2 {
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
  line-height: 1.25;
}
.referral-banner-text p {
  font-size: 14px;
  color: rgba(255,255,255,0.75);
  line-height: 1.65;
  max-width: 480px;
  margin-bottom: 16px;
}
.referral-banner-perks {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 24px;
  padding: 0;
  margin: 0;
}
.referral-banner-perks li {
  font-size: 13px;
  color: rgba(255,255,255,0.85);
  font-weight: 500;
}
.referral-banner-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.btn-referral {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #0d9488;
  color: #fff;
  border: 2px solid #0d9488;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: background .2s, transform .15s;
  box-shadow: 0 4px 16px rgba(13,148,136,0.35);
}
.btn-referral:hover {
  background: #0f766e;
  border-color: #0f766e;
  transform: translateY(-2px);
}
.referral-banner-fax {
  font-size: 12px;
  color: rgba(255,255,255,0.55);
  text-align: center;
}
.referral-banner-fax strong {
  color: rgba(255,255,255,0.8);
}
@media (max-width: 768px) {
  .referral-banner-inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 20px;
  }
  .referral-banner-icon { display: none; }
  .referral-banner-text p { max-width: 100%; }
  .referral-banner-perks { justify-content: center; }
  .referral-banner-cta { width: 100%; }
  .btn-referral { width: 100%; justify-content: center; }
}

/* ── Testimonials Section ─────────────────────────────────────── */
.testimonials-section {
  padding: var(--space-section) 0;
  background: var(--color-surface-offset);
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 2.5rem;
}

.testimonial-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.testimonial-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.1);
  transform: translateY(-2px);
}

.testimonial-stars {
  color: #f59e0b;
  font-size: 1.1rem;
  letter-spacing: 2px;
}

.testimonial-text {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--color-text-primary);
  line-height: 1.7;
  margin: 0;
  flex: 1;
}

.testimonial-author {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
  border-top: 1px solid var(--color-border);
  padding-top: 1rem;
}

.testimonial-name {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-text-secondary);
}

.testimonial-condition {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  padding: 0.2rem 0.6rem;
  border-radius: 99px;
  letter-spacing: 0.02em;
}

.testimonials-cta {
  margin-top: 2.5rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.testimonials-note {
  font-size: 0.95rem;
  color: var(--color-text-secondary);
}

/* ── Floating Feedback Tab ───────────────────────────────────── */
.feedback-tab {
  position: fixed;
  right: -110px;
  top: 50%;
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: right center;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: 8px 8px 0 0;
  padding: 0.6rem 1.1rem;
  font-size: 0.8rem;
  font-weight: 500;
  font-family: var(--font-body);
  letter-spacing: 0.03em;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  z-index: 900;
  transition: right 0.3s ease, background 0.2s;
  right: -102px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.2);
}

.feedback-tab:hover {
  background: var(--color-primary-dark, #0d5f6e);
  right: -96px;
}

/* ── Feedback Modal Overlay ──────────────────────────────────── */
.feedback-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  animation: overlayIn 0.2s ease;
}

.feedback-overlay[hidden] { display: none; }

@keyframes overlayIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.feedback-modal {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  max-width: 480px;
  width: 100%;
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
  animation: modalIn 0.25s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 24px 80px rgba(0,0,0,0.3);
}

@keyframes modalIn {
  from { opacity: 0; transform: translateY(24px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.feedback-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  color: var(--color-text-secondary);
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 4px;
  line-height: 1;
  transition: color 0.15s, background 0.15s;
}

.feedback-close:hover {
  color: var(--color-text-primary);
  background: var(--color-surface-offset);
}

.feedback-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.75rem;
}
.feedback-step[hidden] { display: none !important; }

.feedback-icon {
  margin-bottom: 0.25rem;
}

.feedback-heading {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0;
}

.feedback-sub {
  font-size: 0.95rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
  max-width: 360px;
  margin: 0;
}

.feedback-choices {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  width: 100%;
  margin-top: 0.75rem;
}

.feedback-choice {
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1rem;
  background: var(--color-surface);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
  font-family: var(--font-body);
}

.feedback-choice:hover {
  transform: translateY(-2px);
}

.feedback-choice--positive:hover {
  border-color: #22c55e;
  background: rgba(34,197,94,0.06);
}

.feedback-choice--negative:hover {
  border-color: #f59e0b;
  background: rgba(245,158,11,0.06);
}

.choice-emoji {
  font-size: 2rem;
  line-height: 1;
}

.choice-label {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-text-primary);
}

.choice-desc {
  font-size: 0.78rem;
  color: var(--color-text-secondary);
  line-height: 1.3;
}

.feedback-google-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 0.5rem;
  font-size: 1rem;
}

.feedback-alt {
  font-size: 0.83rem;
  color: var(--color-text-secondary);
  margin: 0;
}

.feedback-alt a {
  color: var(--color-primary);
  text-decoration: underline;
}

.feedback-close-text {
  background: none;
  border: none;
  color: var(--color-text-secondary);
  font-size: 0.83rem;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
  font-family: var(--font-body);
}

.feedback-close-text:hover {
  color: var(--color-text-primary);
}

/* Negative form (left-aligned inside modal) */
.feedback-form {
  width: 100%;
  text-align: left;
  margin-top: 0.5rem;
}

.feedback-form .feedback-heading {
  text-align: left;
  align-self: flex-start;
}

#feedbackStep2Negative {
  align-items: flex-start;
  text-align: left;
}

#feedbackStep2Negative .feedback-sub {
  text-align: left;
}

.feedback-form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.feedback-form-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1rem;
  padding: 1.5rem 0;
  color: var(--color-text-primary);
}

.feedback-form-success[hidden] { display: none; }

.checkbox-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.88rem;
  color: var(--color-text-secondary);
  cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary);
  cursor: pointer;
}

@media (max-width: 480px) {
  .feedback-modal {
    padding: 1.75rem 1.25rem;
  }
  .feedback-choices {
    grid-template-columns: 1fr;
  }
  .testimonials-grid {
    grid-template-columns: 1fr;
  }
}
.form-success[hidden]{display:none!important;}
