/* BlueCliff — Editorial Constructivism
   Asymmetric grids, bold typographic hierarchy, restrained accents, paper texture */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;800;900&family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,900&family=Spline+Sans+Mono:wght@400;500&display=swap');

:root{
  --paper:#e8e2d4;
  --paper-2:#ddd5c2;
  --ink:#13294b;
  --ink-soft:#2c3e5e;
  --accent:#d94f30;
  --accent-2:#c19a3f;
  --line:#b7ad97;
  --white:#f5f1e8;
  --shadow:rgba(19,41,75,.16);
  --maxw:1280px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Archivo',sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}

/* ---------- HEADER ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:var(--ink);color:var(--white);
  border-bottom:3px solid var(--accent);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Fraunces',serif;font-weight:900;font-size:1.5rem;letter-spacing:-.02em}
.brand .mark{width:34px;height:34px;background:var(--accent);display:grid;place-items:center;font-family:'Archivo';font-weight:900;color:var(--white);transform:rotate(-4deg)}
.brand small{display:block;font-family:'Spline Sans Mono',monospace;font-size:.58rem;letter-spacing:.28em;color:var(--accent-2);text-transform:uppercase;font-weight:400}
nav ul{list-style:none;display:flex;gap:26px;align-items:center}
nav a{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;opacity:.85;transition:.2s;position:relative;padding:4px 0}
nav a:hover,nav a[aria-current="page"]{opacity:1;color:var(--accent-2)}
nav a[aria-current="page"]::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--accent)}
.nav-cta{background:var(--accent);color:var(--white)!important;padding:10px 18px!important;opacity:1!important;font-weight:700}
.burger{display:none;background:none;border:none;color:var(--white);cursor:pointer;flex-direction:column;gap:5px}
.burger span{width:26px;height:2.5px;background:var(--white);display:block;transition:.3s}

/* ---------- TYPE ---------- */
h1,h2,h3{font-family:'Fraunces',serif;line-height:1.02;letter-spacing:-.02em;font-weight:900}
.kicker{font-family:'Spline Sans Mono',monospace;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);font-weight:500;display:inline-block;margin-bottom:14px}
.kicker::before{content:"— ";color:var(--accent-2)}

/* ---------- HERO ---------- */
.hero{position:relative;padding:84px 0 70px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(2.8rem,6.4vw,5.6rem)}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero .lead{font-size:1.18rem;max-width:46ch;margin:26px 0 32px;color:var(--ink-soft)}
.hero-num{position:absolute;top:30px;right:-10px;font-family:'Fraunces',serif;font-weight:900;font-size:clamp(8rem,22vw,20rem);color:var(--paper-2);z-index:-1;line-height:.8;opacity:.7}
.hero-media{position:relative}
.hero-media img{width:100%;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--line);filter:contrast(1.05) saturate(.95)}
.hero-media .tag{position:absolute;bottom:-14px;left:-14px;background:var(--accent);color:var(--white);font-family:'Spline Sans Mono',monospace;font-size:.7rem;padding:10px 14px;letter-spacing:.1em;box-shadow:6px 6px 0 var(--ink)}
.hero-media::after{content:"";position:absolute;top:-16px;right:-16px;width:90px;height:90px;border:3px solid var(--accent-2);z-index:-1}

.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;padding:15px 28px;cursor:pointer;border:none;transition:.22s;font-family:'Archivo'}
.btn-primary{background:var(--ink);color:var(--white);box-shadow:5px 5px 0 var(--accent)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--accent)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--white)}
.btn-row{display:flex;gap:16px;flex-wrap:wrap}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--ink);color:var(--white);padding:14px 0;overflow:hidden;border-top:3px solid var(--accent);border-bottom:3px solid var(--accent-2)}
.marquee-track{display:flex;gap:50px;white-space:nowrap;animation:scroll 30s linear infinite;font-family:'Spline Sans Mono',monospace;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase}
.marquee-track span{color:var(--accent-2)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- SECTIONS ---------- */
section{padding:72px 0;position:relative}
.sec-head{max-width:60ch;margin-bottom:48px}
.sec-head h2{font-size:clamp(2rem,4.5vw,3.4rem)}
.sec-head p{margin-top:16px;color:var(--ink-soft);font-size:1.05rem}

/* asymmetric feature grid */
.features{display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
.card{background:var(--white);border:1px solid var(--line);padding:30px;transition:.25s;position:relative}
.card:hover{transform:translateY(-5px);box-shadow:0 16px 30px var(--shadow)}
.card .idx{font-family:'Spline Sans Mono',monospace;font-size:.72rem;color:var(--accent);letter-spacing:.2em}
.card h3{font-size:1.4rem;margin:14px 0 10px}
.card p{font-size:.95rem;color:var(--ink-soft)}
.c4{grid-column:span 4}.c6{grid-column:span 6}.c8{grid-column:span 8}.c12{grid-column:span 12}
.card.dark{background:var(--ink);color:var(--white)}
.card.dark p{color:#c7cfdd}
.card.accent{background:var(--accent);color:var(--white)}
.card.accent .idx{color:var(--white)}
.card.accent p{color:#ffe6df}

/* split image block */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;border:1px solid var(--line)}
.split .pane{padding:54px}
.split .pane.fig{padding:0;overflow:hidden}
.split .pane.fig img{width:100%;height:100%;object-fit:cover;min-height:340px}
.split .pane.ink{background:var(--ink);color:var(--white)}
.split .pane.ink p{color:#c7cfdd}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.stat{padding:38px 20px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .n{font-family:'Fraunces',serif;font-weight:900;font-size:3.2rem;color:var(--accent);line-height:1}
.stat .l{font-family:'Spline Sans Mono',monospace;font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;margin-top:8px;color:var(--ink-soft)}

/* ---------- PRICING ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.price-card{background:var(--white);border:1px solid var(--line);padding:36px 30px;position:relative;transition:.25s}
.price-card.feat{background:var(--ink);color:var(--white);transform:scale(1.03);box-shadow:8px 8px 0 var(--accent)}
.price-card.feat .plan-sub,.price-card.feat li{color:#c7cfdd}
.price-card .badge{position:absolute;top:-14px;right:24px;background:var(--accent);color:#fff;font-family:'Spline Sans Mono',monospace;font-size:.66rem;padding:6px 12px;letter-spacing:.1em;text-transform:uppercase}
.plan-name{font-family:'Fraunces',serif;font-weight:900;font-size:1.5rem}
.plan-sub{font-size:.88rem;color:var(--ink-soft);margin:6px 0 22px;min-height:42px}
.price{font-family:'Fraunces',serif;font-weight:900;font-size:3rem;line-height:1}
.price small{font-family:'Spline Sans Mono',monospace;font-size:.8rem;font-weight:400;color:var(--accent-2)}
.price-card ul{list-style:none;margin:24px 0 28px}
.price-card li{padding:9px 0;border-bottom:1px dashed var(--line);font-size:.92rem;display:flex;gap:10px;align-items:flex-start}
.price-card li::before{content:"›";color:var(--accent);font-weight:900}
.price-card.feat li{border-color:#2c3e5e}
.price-card .btn{width:100%;justify-content:center}

/* ---------- STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{padding:28px;border-top:3px solid var(--accent)}
.step .num{font-family:'Fraunces',serif;font-weight:900;font-size:2.6rem;color:var(--accent)}
.step h3{font-size:1.2rem;margin:8px 0 8px}
.step p{font-size:.92rem;color:var(--ink-soft)}

/* ---------- TEAM / GALLERY ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.member{background:var(--white);border:1px solid var(--line)}
.member img{width:100%;aspect-ratio:1/1;object-fit:cover;filter:grayscale(.3) contrast(1.05)}
.member .body{padding:22px}
.member h3{font-size:1.25rem}
.member .role{font-family:'Spline Sans Mono',monospace;font-size:.72rem;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-top:4px}
.member p{font-size:.9rem;color:var(--ink-soft);margin-top:12px}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:24px 0;font-family:'Fraunces',serif;font-weight:600;font-size:1.25rem;cursor:pointer;display:flex;justify-content:space-between;gap:20px;color:var(--ink)}
.faq-q::after{content:"+";color:var(--accent);font-size:1.6rem;transition:.3s}
.faq-q[aria-expanded="true"]::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-soft)}
.faq-a p{padding:0 0 24px;max-width:70ch}

/* ---------- FORM ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.info-block{margin-bottom:26px}
.info-block .lab{font-family:'Spline Sans Mono',monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.info-block .val{font-size:1.1rem;font-weight:600}
form.cf{background:var(--white);border:1px solid var(--line);padding:36px}
.field{margin-bottom:20px}
.field label{display:block;font-family:'Spline Sans Mono',monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;color:var(--ink-soft)}
.field input,.field textarea,.field select{width:100%;padding:13px 14px;border:1px solid var(--line);background:var(--paper);font-family:'Archivo';font-size:.95rem;color:var(--ink);transition:.2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.check{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--ink-soft)}
.check input{width:auto;margin-top:4px}
.form-msg{margin-top:16px;padding:14px;background:var(--ink);color:var(--white);font-size:.9rem;display:none}
.form-msg.show{display:block}

/* ---------- CTA banner ---------- */
.cta-banner{background:var(--ink);color:var(--white);text-align:center;padding:70px 28px;position:relative;overflow:hidden}
.cta-banner h2{font-size:clamp(2rem,5vw,3.6rem);max-width:18ch;margin:0 auto 24px}
.cta-banner h2 em{color:var(--accent);font-style:italic}
.cta-banner .deco{position:absolute;font-family:'Fraunces';font-weight:900;font-size:14rem;color:#1b3460;top:-40px;left:-20px;z-index:0;opacity:.5}

/* ---------- FOOTER ---------- */
footer.site{background:var(--ink);color:var(--white);padding:60px 0 28px;border-top:3px solid var(--accent)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:36px;margin-bottom:42px}
footer .brand{color:var(--white);margin-bottom:16px}
footer p{color:#9fb0c9;font-size:.9rem;max-width:34ch}
.foot-col h4{font-family:'Spline Sans Mono',monospace;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);margin-bottom:16px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:10px}
.foot-col a{font-size:.9rem;color:#c7cfdd;transition:.2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{border-top:1px solid #2c3e5e;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.8rem;color:#9fb0c9}
.foot-bottom a{color:#9fb0c9}.foot-bottom a:hover{color:var(--accent)}

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero{background:var(--ink);color:var(--white);padding:70px 0 60px;position:relative;overflow:hidden;border-bottom:3px solid var(--accent)}
.page-hero .kicker{color:var(--accent-2)}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.4rem);max-width:18ch}
.page-hero p{margin-top:18px;color:#c7cfdd;max-width:54ch;font-size:1.08rem}
.page-hero .big-n{position:absolute;right:-10px;bottom:-50px;font-family:'Fraunces';font-weight:900;font-size:16rem;color:#1b3460;opacity:.5;line-height:.7}
.crumb{font-family:'Spline Sans Mono',monospace;font-size:.74rem;letter-spacing:.1em;color:#9fb0c9;margin-bottom:18px}
.crumb a:hover{color:var(--accent)}

/* ---------- LEGAL / PROSE ---------- */
.prose{max-width:78ch}
.prose h2{font-size:1.7rem;margin:40px 0 14px}
.prose h3{font-size:1.25rem;margin:28px 0 10px;font-family:'Fraunces';font-weight:600}
.prose p{margin-bottom:16px;color:var(--ink-soft)}
.prose ul{margin:0 0 18px 22px;color:var(--ink-soft)}
.prose li{margin-bottom:8px}
.prose .updated{font-family:'Spline Sans Mono',monospace;font-size:.78rem;color:var(--accent);margin-bottom:30px;letter-spacing:.06em}
.toc{background:var(--white);border:1px solid var(--line);padding:26px 30px;margin-bottom:36px}
.toc h4{font-family:'Spline Sans Mono',monospace;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.toc ul{list-style:none;columns:2;gap:20px}
.toc li{margin-bottom:8px;font-size:.9rem}
.toc a:hover{color:var(--accent)}

/* ---------- COOKIE BANNER ---------- */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;max-width:520px;margin:0 auto;background:var(--ink);color:var(--white);border:2px solid var(--accent);padding:24px;z-index:200;box-shadow:0 20px 40px rgba(0,0,0,.3);display:none}
.cookie.show{display:block;animation:slideup .4s ease}
@keyframes slideup{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie h4{font-family:'Fraunces';font-size:1.2rem;margin-bottom:8px}
.cookie p{font-size:.86rem;color:#c7cfdd;margin-bottom:16px}
.cookie p a{color:var(--accent-2);text-decoration:underline}
.cookie-btns{display:flex;gap:12px;flex-wrap:wrap}
.cookie-btns .btn{padding:11px 20px;font-size:.78rem}
.btn-small-ghost{background:transparent;color:var(--white);border:1.5px solid #4a5d7d}
.btn-small-ghost:hover{border-color:var(--white)}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-num{display:none}
  .features{grid-template-columns:repeat(6,1fr)}
  .c4{grid-column:span 6}.c8{grid-column:span 6}
  .pricing{grid-template-columns:1fr}
  .price-card.feat{transform:none}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .steps{grid-template-columns:repeat(2,1fr)}
  .grid3{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .toc ul{columns:1}
}
@media(max-width:640px){
  nav ul{display:none;position:absolute;top:74px;left:0;right:0;background:var(--ink);flex-direction:column;padding:20px 28px;gap:16px;border-bottom:3px solid var(--accent)}
  nav ul.open{display:flex}
  .burger{display:flex}
  .features{grid-template-columns:1fr}
  .c4,.c6,.c8,.c12{grid-column:span 1}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .steps,.grid3{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .split .pane{padding:34px}
  .wrap{padding:0 20px}
}
