@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght,SOFT@9..144,300..900,0..100&family=Manrope:wght@300;400;500;600;700&display=swap');

:root{
  --cream:#F4F1EA;
  --cream-deep:#EBE6DA;
  --ink:#16140F;
  --ink-soft:#3A362C;
  --muted:#7C7668;
  --rust:#B5462E;
  --rust-deep:#8E3520;
  --line:rgba(22,20,15,0.12);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Manrope',-apple-system,sans-serif;
  --max:1240px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
}
::selection{background:var(--rust);color:var(--cream)}
a{color:inherit;text-decoration:none;transition:color .25s ease}
a:hover{color:var(--rust)}
img{max-width:100%;display:block}

/* ─── Grain overlay for texture ─── */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  opacity:.07;mix-blend-mode:multiply;
}

/* ─── Layout ─── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 40px;position:relative;z-index:2}
@media(max-width:640px){.wrap{padding:0 24px}}

/* ─── Nav ─── */
.nav{padding:32px 0;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:10}
.brand{font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:-0.01em;display:flex;align-items:center;gap:10px}
.brand-mark{width:10px;height:10px;background:var(--rust);border-radius:50%;display:inline-block}
.nav-links{display:flex;gap:38px;font-size:14px;font-weight:500;letter-spacing:0.02em;text-transform:uppercase}
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--rust);transition:width .35s ease}
.nav-links a:hover::after{width:100%}
@media(max-width:640px){.nav-links{gap:22px;font-size:12px}}

/* ─── Hero ─── */
.hero{padding:80px 0 140px;position:relative}
.eyebrow{font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-bottom:36px;display:flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--rust)}
.display{
  font-family:var(--serif);
  font-size:clamp(48px,8vw,116px);
  line-height:0.96;
  letter-spacing:-0.035em;
  font-weight:340;
  font-variation-settings:"opsz" 144,"SOFT" 30;
  max-width:14ch;
  margin-bottom:48px;
}
.display em{font-style:italic;color:var(--rust);font-variation-settings:"opsz" 144,"SOFT" 80}
.lede{font-size:19px;max-width:52ch;color:var(--ink-soft);line-height:1.6;margin-bottom:56px}
.cta-row{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;background:var(--ink);color:var(--cream);
  font-size:14px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;
  border-radius:999px;transition:all .3s ease;border:1px solid var(--ink);
}
.btn:hover{background:var(--rust);border-color:var(--rust);color:var(--cream);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn .arrow{transition:transform .3s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* Floating hero ornament */
.hero-ornament{
  position:absolute;right:-60px;top:80px;width:340px;height:340px;
  border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-style:italic;font-size:22px;color:var(--muted);
  animation:spin 60s linear infinite;
}
.hero-ornament::before{
  content:"";position:absolute;inset:30px;border:1px dashed var(--line);border-radius:50%;
}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:900px){.hero-ornament{display:none}}

/* ─── Sections ─── */
section{padding:120px 0;position:relative}
.section-head{margin-bottom:80px;max-width:720px}
.section-num{font-family:var(--serif);font-style:italic;color:var(--rust);font-size:18px;margin-bottom:16px;display:block}
.section-title{font-family:var(--serif);font-size:clamp(36px,5vw,60px);line-height:1.05;letter-spacing:-0.025em;font-weight:380;margin-bottom:24px}
.section-title em{font-style:italic;color:var(--rust)}
.section-sub{font-size:18px;color:var(--ink-soft);max-width:55ch}

/* ─── Product / showcase grid ─── */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
.card{
  grid-column:span 4;
  background:var(--cream-deep);
  padding:44px 36px;
  border-radius:18px;
  border:1px solid var(--line);
  transition:all .4s cubic-bezier(.2,.8,.2,1);
  position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);border-color:var(--rust);background:var(--cream)}
.card-num{font-family:var(--serif);font-style:italic;color:var(--rust);font-size:14px;margin-bottom:28px;display:block}
.card-title{font-family:var(--serif);font-size:30px;line-height:1.1;font-weight:420;margin-bottom:18px;letter-spacing:-0.015em}
.card-body{font-size:15px;color:var(--ink-soft);line-height:1.65}
.card-link{display:inline-flex;align-items:center;gap:8px;margin-top:28px;font-size:13px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--ink)}
.card-link::after{content:"→";transition:transform .3s}
.card:hover .card-link::after{transform:translateX(4px)}
@media(max-width:900px){.card{grid-column:span 6}}
@media(max-width:600px){.card{grid-column:span 12}}

/* ─── Pricing ─── */
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:920px;margin:0 auto}
.tier{padding:52px 44px;border-radius:20px;border:1px solid var(--line);background:var(--cream-deep);position:relative}
.tier.featured{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.tier.featured .tier-price small,.tier.featured .tier-name{color:rgba(244,241,234,0.7)}
.tier-name{font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
.tier-price{font-family:var(--serif);font-size:64px;font-weight:380;letter-spacing:-0.03em;line-height:1;margin-bottom:8px}
.tier-price small{font-size:16px;color:var(--muted);font-family:var(--sans);font-weight:400}
.tier-feats{list-style:none;margin:36px 0;padding:0}
.tier-feats li{padding:14px 0;border-bottom:1px solid var(--line);font-size:15px;display:flex;align-items:center;gap:12px}
.tier.featured .tier-feats li{border-color:rgba(244,241,234,0.15)}
.tier-feats li::before{content:"✦";color:var(--rust);font-size:12px}
@media(max-width:760px){.tiers{grid-template-columns:1fr}}

/* ─── Page header (interior pages) ─── */
.page-head{padding:60px 0 100px}
.page-title{font-family:var(--serif);font-size:clamp(48px,7vw,88px);line-height:1;letter-spacing:-0.03em;font-weight:360;margin-top:24px}
.page-title em{font-style:italic;color:var(--rust)}

/* ─── Prose (legal pages) ─── */
.prose{max-width:680px;margin:0 auto}
.prose h2{font-family:var(--serif);font-size:32px;font-weight:420;margin-top:64px;margin-bottom:20px;letter-spacing:-0.015em}
.prose h2:first-child{margin-top:0}
.prose p{margin-bottom:20px;color:var(--ink-soft);font-size:17px}
.prose ul{margin:20px 0 28px 24px;color:var(--ink-soft)}
.prose li{margin-bottom:10px}
.prose strong{color:var(--ink);font-weight:600}

/* ─── Contact form ─── */
.form{max-width:560px;margin:0 auto;display:grid;gap:24px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:600}
.field input,.field textarea{
  font-family:var(--sans);font-size:16px;padding:16px 0;
  background:transparent;border:none;border-bottom:1px solid var(--line);
  color:var(--ink);transition:border-color .3s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--rust)}
.field textarea{resize:vertical;min-height:120px}
.form-status{margin-top:8px;font-size:14px;line-height:1.5;min-height:1.5em}
.form-status.success{color:var(--rust);font-weight:500}
.form-status.error{color:#B5462E;font-weight:500}
.form button:disabled{opacity:0.6;cursor:not-allowed}

/* ─── Footer ─── */
footer{padding:100px 0 50px;border-top:1px solid var(--line);margin-top:80px}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;margin-bottom:80px}
.foot-brand{font-family:var(--serif);font-size:42px;line-height:1;font-weight:380;letter-spacing:-0.02em;max-width:10ch}
.foot-brand em{font-style:italic;color:var(--rust)}
.foot h4{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;font-weight:600}
.foot ul{list-style:none}
.foot li{margin-bottom:12px;font-size:15px}
.foot-bottom{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);padding-top:32px;border-top:1px solid var(--line);flex-wrap:wrap;gap:16px}
@media(max-width:760px){.foot{grid-template-columns:1fr;gap:40px}}

/* ─── Showcase tiles ─── */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:20px}
.tile{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:var(--cream-deep);transition:all .5s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;text-decoration:none;color:inherit}
.tile:hover{transform:translateY(-8px);border-color:var(--rust);box-shadow:0 30px 60px -20px rgba(22,20,15,0.18)}
.tile-preview{aspect-ratio:16/10;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.tile-preview.ecg{background:radial-gradient(circle at 50% 55%,#221f1a 0%,#000 100%)}
.tile-preview.cte{background:linear-gradient(135deg,#F4F1EA 0%,#E5DFD0 100%)}
.tile-preview .mark{position:relative;z-index:2;font-family:var(--serif);font-style:italic;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.tile:hover .tile-preview .mark{transform:scale(1.05)}
.tile-preview.ecg .mark{font-size:64px;color:#B8865A;letter-spacing:0.04em;font-weight:500;text-shadow:0 4px 30px rgba(184,134,90,0.3)}
.tile-preview.cte .mark{font-size:54px;color:var(--rust);letter-spacing:-0.02em}
.tile-preview .grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(184,134,90,0.06) 1px,transparent 1px),linear-gradient(90deg,rgba(184,134,90,0.06) 1px,transparent 1px);background-size:32px 32px}
.tile-preview.cte .grid-bg{background-image:linear-gradient(rgba(181,70,46,0.06) 1px,transparent 1px),linear-gradient(90deg,rgba(181,70,46,0.06) 1px,transparent 1px)}
.tile-body{padding:36px 38px 38px}
.tile-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.tile-kind{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--rust);font-weight:700}
.tile-year{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:14px}
.tile-title{font-family:var(--serif);font-size:34px;line-height:1.05;font-weight:420;letter-spacing:-0.018em;margin-bottom:14px}
.tile-desc{font-size:15px;color:var(--ink-soft);line-height:1.6;margin-bottom:24px}
.tile-cta{font-size:13px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.tile-cta::after{content:"→";transition:transform .3s}
.tile:hover .tile-cta::after{transform:translateX(5px)}
@media(max-width:880px){.showcase{grid-template-columns:1fr}}

/* ─── Reveal animations ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.2,.8,.2,1),transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}