/* Frame of Mind v3 - Bright white + purple palette */
:root{
  --bg:#FDFBF7;
  --bg-soft:#F5F2FB;
  --bg-cream:#F5F2FB;
  --bg-cream-2:#EDE6F5;
  --panel:#FFFFFF;
  --ink:#1A1520;
  --ink-2:#4A4152;
  --mute:#8A7F95;
  --mute-2:#BBB0C4;
  --line:rgba(83,46,109,0.12);
  --line-2:rgba(83,46,109,0.22);
  --oak:#532E6D;
  --oak-light:#8A6FB5;
  --oak-deep:#3A1F4D;
  --accent:#7C5AC4;
  --gold:#6B4EBF;
  --purple:#532E6D;
  --purple-light:#8A6FB5;
  --purple-soft:#E8DFF3;
  --purple-deep:#3A1F4D;
  --max:1440px;
  --gutter:clamp(20px,4vw,56px);
  --radius:3px;
  --ease:cubic-bezier(0.77,0,0.18,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55}
::selection{background:var(--purple);color:#FFFFFF}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Nav */
.nav{position:sticky;top:0;left:0;right:0;z-index:100;padding:16px var(--gutter);display:flex;justify-content:space-between;align-items:center;background:rgba(253,251,247,0.88);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);transition:padding 0.3s var(--ease)}
.nav.scrolled{padding-top:12px;padding-bottom:12px}
.nav-logo{font-family:var(--serif);font-weight:400;font-size:20px;letter-spacing:-0.01em;display:flex;align-items:center;gap:12px;color:var(--ink)}
.nav-logo-gif{width:38px;height:38px;border-radius:50%;display:block;background:var(--ink);padding:3px;flex-shrink:0}
.nav-links{display:flex;gap:26px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:0.16em;color:var(--ink-2)}
.nav-links a{position:relative;padding:4px 0;transition:color 0.3s}
.nav-links a:hover,.nav-links a.active{color:var(--purple)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--purple);transform:scaleX(0);transform-origin:right;transition:transform 0.4s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-cta{padding:9px 16px;border:1px solid var(--purple);border-radius:999px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:0.14em;color:var(--purple);transition:background 0.3s,color 0.3s}
.nav-cta:hover{background:var(--purple);color:#FFFFFF}
.nav-burger{display:none;background:none;border:none;color:var(--ink);padding:0;cursor:pointer}
.nav-burger span{display:block;width:26px;height:1.5px;background:currentColor;margin:7px 0}
.m-menu{position:fixed;inset:0;background:var(--bg);z-index:200;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px;opacity:0;visibility:hidden;transition:opacity 0.4s,visibility 0s linear 0.4s}
.m-menu.open{opacity:1;visibility:visible;transition-delay:0s}
.m-menu a{color:var(--ink);font-family:var(--serif);font-size:30px;font-weight:400}
.m-close{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--ink);font-size:30px;cursor:pointer}
@media(max-width:960px){.nav-links,.nav-cta{display:none}.nav-burger{display:block}}

/* Breadcrumb */
.breadcrumb{padding:16px var(--gutter);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--mute);border-bottom:1px solid var(--line);display:flex;gap:12px;align-items:center;background:var(--bg)}
.breadcrumb a{color:var(--ink-2);transition:color 0.3s}
.breadcrumb a:hover{color:var(--purple)}
.breadcrumb .sep{color:var(--mute-2)}

/* Page hero */
.page-hero{padding:80px var(--gutter) 60px;max-width:var(--max);margin:0 auto;position:relative;border-bottom:1px solid var(--line)}
.page-hero-eyebrow{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--purple);margin-bottom:20px;display:flex;align-items:center;gap:12px}
.page-hero-eyebrow::before{content:"";width:28px;height:1px;background:currentColor}
.page-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(44px,7vw,108px);line-height:0.96;letter-spacing:-0.03em;margin-bottom:26px;color:var(--ink)}
.page-hero h1 .italic{font-style:italic;color:var(--purple)}
.page-hero p.lead{font-size:18px;line-height:1.6;max-width:620px;color:var(--ink-2)}
.page-hero-ctas{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}

/* Section wrapper */
.section{padding:clamp(60px,10vh,120px) var(--gutter);position:relative}
.section.tight{padding:48px var(--gutter)}
.section.light{background:var(--purple-soft);color:var(--ink)}
.section-inner{max-width:var(--max);margin:0 auto}
.section-head{display:grid;grid-template-columns:1fr 2fr;gap:40px;margin-bottom:44px;align-items:end}
@media(max-width:760px){.section-head{grid-template-columns:1fr;gap:18px}}
.section-tag{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--purple);display:flex;align-items:center;gap:12px;margin-bottom:12px}
.section-tag::before{content:"";width:22px;height:1px;background:currentColor}
.section-heading{font-family:var(--serif);font-weight:300;font-size:clamp(32px,5vw,72px);line-height:0.98;letter-spacing:-0.025em;color:var(--ink)}
.section-heading .italic{font-style:italic;color:var(--purple)}
.section-sub{font-size:16px;line-height:1.6;max-width:480px;color:var(--ink-2)}

/* Btn */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;background:var(--purple);color:#FFFFFF;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.18em;border-radius:999px;border:1px solid var(--purple);transition:transform 0.3s,background 0.3s;cursor:pointer;font-family:inherit}
.btn:hover{transform:translateY(-2px);background:var(--purple-deep);border-color:var(--purple-deep)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn.ghost:hover{background:var(--ink);color:#FFFFFF;border-color:var(--ink)}
.btn.sm{padding:10px 18px;font-size:11px}

/* Prose */
.prose{max-width:720px;margin:0 auto;font-size:16.5px;line-height:1.75;color:var(--ink-2)}
.prose h2{font-family:var(--serif);font-size:36px;font-weight:400;letter-spacing:-0.015em;margin:40px 0 16px;color:var(--ink);line-height:1.2}
.prose h3{font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:-0.01em;margin:28px 0 12px;color:var(--ink)}
.prose p{margin-bottom:18px}
.prose ul,.prose ol{margin:14px 0 20px;padding-left:22px}
.prose ul li,.prose ol li{margin-bottom:6px}
.prose blockquote{border-left:2px solid var(--purple);padding:4px 20px;margin:28px 0;font-family:var(--serif);font-style:italic;font-size:22px;color:var(--purple)}
.prose a{color:var(--purple);border-bottom:1px solid var(--purple-light);transition:color 0.3s}
.prose a:hover{color:var(--purple-deep)}
.prose strong{color:var(--ink);font-weight:600}
.prose img{border-radius:var(--radius);margin:28px 0;width:100%}
.prose hr{border:none;border-top:1px solid var(--line);margin:40px 0}

/* Footer — dark plum for contrast */
footer{background:var(--purple-deep);color:#FDFBF7;padding:70px var(--gutter) 30px;border-top:1px solid var(--line)}
.footer-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:42px;border-bottom:1px solid rgba(253,251,247,0.12)}
.footer-brand h3{font-family:var(--serif);font-size:32px;font-weight:400;margin-bottom:14px;letter-spacing:-0.015em;color:#FDFBF7}
.footer-brand p{color:rgba(253,251,247,0.75);font-size:13.5px;line-height:1.7;max-width:340px;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:38px;height:38px;border:1px solid rgba(253,251,247,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;letter-spacing:0.1em;color:#FDFBF7;transition:all 0.3s}
.footer-social a:hover{background:var(--purple-light);border-color:var(--purple-light);color:var(--purple-deep)}
.footer-col h5{font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--purple-light);margin-bottom:14px;font-weight:600}
.footer-col a{display:block;color:#FDFBF7;font-size:13px;padding:4px 0;opacity:0.85;transition:opacity 0.3s,padding-left 0.3s}
.footer-col a:hover{opacity:1;padding-left:5px;color:var(--purple-light)}
.footer-bottom{max-width:var(--max);margin:24px auto 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:11px;color:rgba(253,251,247,0.5);letter-spacing:0.05em}
@media(max-width:960px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr}}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.8s var(--ease-out),transform 0.8s var(--ease-out)}
.reveal.in-view{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:0.1s}
.reveal.d2{transition-delay:0.2s}
.reveal.d3{transition-delay:0.3s}

/* Float quote */
.float-quote{position:fixed;bottom:22px;right:22px;padding:13px 20px;background:var(--purple);color:#FFFFFF;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.18em;box-shadow:0 20px 40px rgba(83,46,109,0.25);z-index:50;display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(60px);transition:opacity 0.5s var(--ease),transform 0.5s var(--ease),background 0.3s}
.float-quote.show{opacity:1;transform:translateY(0)}
.float-quote:hover{background:var(--purple-deep)}
.float-quote-dot{width:7px;height:7px;border-radius:50%;background:#FFFFFF;animation:pulse 1.5s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.8);opacity:0.4}}

/* Accessibility */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--purple);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}html{scroll-behavior:auto}}

/* Cards */
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:960px){.card-grid-3,.card-grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.card-grid-3,.card-grid-4,.card-grid-2{grid-template-columns:1fr}}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:32px;transition:border-color 0.4s,transform 0.4s,box-shadow 0.4s}
.card:hover{border-color:var(--purple);transform:translateY(-3px);box-shadow:0 30px 60px -20px rgba(83,46,109,0.15)}
.card-num{font-family:var(--mono);font-size:11px;color:var(--purple);letter-spacing:0.15em;margin-bottom:18px}
.card h3{font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:-0.015em;margin-bottom:10px;color:var(--ink)}
.card p{font-size:14px;line-height:1.6;color:var(--ink-2)}

/* CTA big */
.cta-big{background:var(--purple);color:#FFFFFF;padding:clamp(70px,12vh,130px) var(--gutter);text-align:center;position:relative;overflow:hidden}
.cta-big-bg{position:absolute;inset:0;background-image:url('https://lirp.cdn-website.com/76ffefb9/dms3rep/multi/opt/FoM_06-1920w.jpg');background-size:cover;background-position:center;opacity:0.14;mix-blend-mode:luminosity}
.cta-big h2{font-family:var(--serif);font-size:clamp(36px,6vw,80px);font-weight:300;line-height:1;letter-spacing:-0.025em;margin-bottom:22px;position:relative;color:#FFFFFF}
.cta-big h2 .italic{font-style:italic;color:#E8DFF3}
.cta-big p{font-size:16px;max-width:520px;margin:0 auto 28px;color:rgba(255,255,255,0.9);position:relative}
.cta-big .cta-row{position:relative;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-big .btn{background:#FFFFFF;color:var(--purple);border-color:#FFFFFF}
.cta-big .btn:hover{background:#E8DFF3;border-color:#E8DFF3;color:var(--purple-deep)}
.cta-big .btn.ghost{background:transparent;color:#FFFFFF;border-color:#FFFFFF}
.cta-big .btn.ghost:hover{background:#FFFFFF;color:var(--purple)}

/* FAQ styles for service pages */
.faq-list{max-width:780px;margin:0 auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line);cursor:pointer}
.faq-q{padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--serif);font-size:clamp(18px,2.2vw,24px);font-weight:400;letter-spacing:-0.01em;transition:color 0.3s;color:var(--ink)}
.faq-item:hover .faq-q{color:var(--purple)}
.faq-icon{width:28px;height:28px;position:relative;flex-shrink:0}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;top:50%;left:50%;background:var(--ink);transition:transform 0.4s}
.faq-icon::before{width:12px;height:1px;transform:translate(-50%,-50%)}
.faq-icon::after{width:1px;height:12px;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.5s,padding 0.5s;color:var(--ink-2);font-size:15px;line-height:1.65}
.faq-item.open .faq-a{max-height:400px;padding-bottom:22px}
