/* ============================================================
   TaraLens Media — styles.css
   Responsive rebuild of the 1440px mockup. Same identity:
   cream / charcoal / rust, Cormorant Garamond + Barlow.
   Fluid layout, real breakpoints, accessible states.
   ============================================================ */

:root{
  --cream:#f4ede2;
  --cream-2:#efe6d8;
  --charcoal:#1c1814;
  --near-black:#141019;
  --ink:#241f1a;
  --rust:#b5502a;
  --rust-deep:#9c4322;
  --terracotta:#c2683f;
  --olive:#6e6a4f;
  --muted:#7a7066;
  --line:#d8ccba;
  --line-dark:#3a342d;
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Barlow',system-ui,-apple-system,sans-serif;
  --cond:'Barlow Condensed','Arial Narrow',sans-serif;
  --maxw:1280px;
  --gutter:clamp(20px,5vw,48px);
  --focus:#2f7dd1;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}
}
body{
  background:var(--cream);
  font-family:var(--sans);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:hidden;
}
img,picture,svg{display:block;max-width:100%;}
a{color:inherit;}

/* visible focus everywhere for keyboard users */
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;}

.skip-link{
  position:absolute;left:8px;top:-48px;background:var(--ink);color:var(--cream);
  padding:10px 16px;z-index:1000;font-family:var(--cond);letter-spacing:.12em;
  text-transform:uppercase;font-size:13px;text-decoration:none;transition:top .15s;
}
.skip-link:focus{top:8px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);}

/* ---------- type helpers ---------- */
.eyebrow{font-family:var(--cond);letter-spacing:.22em;text-transform:uppercase;font-size:13px;font-weight:600;}
.label{font-family:var(--cond);letter-spacing:.18em;text-transform:uppercase;font-size:12px;font-weight:600;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--cond);letter-spacing:.14em;text-transform:uppercase;
  font-size:13px;font-weight:600;padding:15px 26px;border:1.5px solid transparent;
  cursor:pointer;text-decoration:none;transition:background .18s,color .18s,border-color .18s,transform .18s;
}
.btn:hover{transform:translateY(-1px);}
.btn-rust{background:var(--rust);color:var(--cream);}
.btn-rust:visited,.btn-rust:hover,.btn-rust:focus,.btn-rust:active{color:var(--cream);}
.btn-rust:hover{background:var(--rust-deep);}
.btn-ghost-light{background:transparent;color:var(--cream);border-color:rgba(244,237,226,.55);}
.btn-ghost-light:hover{border-color:var(--cream);background:rgba(244,237,226,.08);}
.btn-ghost-dark{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-ghost-dark:hover{background:var(--ink);color:var(--cream);}
.btn-white{background:var(--cream);color:var(--ink);}
.btn-white:hover{background:#fff;}

.arrow-link{
  font-family:var(--cond);letter-spacing:.14em;text-transform:uppercase;
  font-size:12px;font-weight:600;text-decoration:none;color:inherit;
  border-bottom:1.5px solid currentColor;padding-bottom:3px;display:inline-block;
  transition:opacity .15s,gap .15s;
}
.arrow-link:hover{opacity:.7;}

/* ============ IMAGE FRAMES ============ */
.frame{display:block;position:relative;overflow:hidden;background:#26211b;}
.frame img{width:100%;height:100%;object-fit:cover;display:block;}

/* ============ HEADER ============ */
.header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:16px var(--gutter);
  background:var(--near-black);color:var(--cream);
  border-bottom:1px solid var(--line-dark);
}
.header .brand{display:flex;align-items:center;text-decoration:none;flex:0 0 auto;}
.header .brand img{height:40px;width:auto;}
.nav{display:flex;gap:clamp(16px,2vw,30px);align-items:center;}
.nav a{
  color:var(--cream);text-decoration:none;font-family:var(--cond);
  letter-spacing:.13em;text-transform:uppercase;font-size:13px;font-weight:500;
  padding:4px 0;border-bottom:2px solid transparent;white-space:nowrap;
}
.nav a:hover{border-bottom-color:rgba(181,80,42,.6);}
.nav a[aria-current="page"]{border-bottom-color:var(--rust);}
.header-cta{display:flex;gap:10px;flex:0 0 auto;}
.header-cta .btn{padding:11px 18px;font-size:12px;}

/* mobile menu toggle */
.menu-toggle{
  display:none;background:none;border:1.5px solid rgba(244,237,226,.4);
  color:var(--cream);padding:9px 12px;cursor:pointer;font-family:var(--cond);
  letter-spacing:.1em;text-transform:uppercase;font-size:12px;align-items:center;gap:8px;
}
.menu-toggle .bars{display:inline-block;width:18px;height:2px;background:var(--cream);position:relative;}
.menu-toggle .bars::before,.menu-toggle .bars::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--cream);}
.menu-toggle .bars::before{top:-6px;}
.menu-toggle .bars::after{top:6px;}

/* ============ HERO ============ */
.hero{position:relative;min-height:clamp(460px,72vh,640px);background:linear-gradient(105deg,#0d0a14 0%,#1a1018 45%,#3a1d14 100%);overflow:hidden;display:flex;align-items:center;}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:50% 42%;opacity:.62;}
.hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(13,10,20,.92) 0%,rgba(26,16,24,.7) 45%,rgba(58,29,20,.4) 100%);}
.hero__content{position:relative;z-index:2;padding:clamp(40px,7vw,74px) 0;max-width:640px;}
.hero h1{font-family:var(--serif);color:var(--cream);font-weight:500;font-size:clamp(42px,7vw,74px);line-height:1.02;letter-spacing:.005em;}
.hero h1 em{color:var(--terracotta);font-style:italic;}
.hero .rule{width:54px;height:2px;background:var(--rust);margin:24px 0 22px;}
.hero p.sub{color:rgba(244,237,226,.88);font-size:clamp(15px,2vw,17px);line-height:1.6;max-width:440px;font-weight:300;}
.hero .eyebrow{color:var(--terracotta);margin-bottom:20px;}
.hero-btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;}

/* ============ TRUST BAR ============ */
.trust{background:var(--cream-2);border-bottom:1px solid var(--line);}
.trust .grid{display:grid;grid-template-columns:repeat(4,1fr);}
.trust .cell{display:flex;gap:14px;padding:24px var(--gutter);align-items:flex-start;border-right:1px solid var(--line);}
.trust .cell:last-child{border-right:none;}
.trust .ic{width:30px;height:30px;flex:0 0 30px;color:var(--rust);}
.trust .ic svg{width:30px;height:30px;}
.trust .t{font-family:var(--cond);letter-spacing:.1em;text-transform:uppercase;font-size:12px;font-weight:600;color:var(--ink);line-height:1.4;}
.trust .d{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.5;}

/* ============ SECTION SHELLS ============ */
.section{padding:clamp(40px,6vw,64px) 0;}
.section--dark{background:var(--near-black);color:var(--cream);}
.section--charcoal{background:var(--charcoal);color:var(--cream);}
.section--cream{background:var(--cream);}
.section--cream2{background:var(--cream-2);border-top:1px solid var(--line);}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:30px;flex-wrap:wrap;}
.section-head h2{font-family:var(--serif);font-size:clamp(30px,4.4vw,40px);font-weight:500;line-height:1.08;}
.section--dark .section-head h2,.section--charcoal .section-head h2{color:var(--cream);}
.section-head .eyebrow{margin-bottom:10px;color:var(--rust);}
.section--dark .section-head .eyebrow,.section--charcoal .section-head .eyebrow{color:var(--terracotta);}

/* ============ EXPERIENCE CARDS ============ */
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.exp-card{position:relative;min-height:340px;overflow:hidden;display:block;text-decoration:none;}
.exp-card .frame{position:absolute;inset:0;}
.exp-card .frame img{transition:transform .5s ease;}
.exp-card:hover .frame img{transform:scale(1.05);}
.exp-card .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,12,.05) 30%,rgba(15,10,8,.92) 100%);}
.exp-card .text{position:absolute;left:22px;right:22px;bottom:22px;color:var(--cream);z-index:2;}
.exp-card h3{font-family:var(--cond);letter-spacing:.08em;text-transform:uppercase;font-size:17px;font-weight:600;line-height:1.2;}
.exp-card p{font-size:13px;line-height:1.5;color:rgba(244,237,226,.85);margin:10px 0 14px;font-weight:300;}
.exp-card .arrow-link{color:var(--cream);font-size:11px;}

/* ============ ORIGIN ============ */
.origin{display:grid;grid-template-columns:minmax(280px,360px) 1fr minmax(180px,220px);background:var(--cream);align-items:stretch;}
.origin .photo{min-height:430px;}
.origin .photo img{width:100%;height:100%;object-fit:cover;object-position:50% 38%;}
.origin .mid{padding:clamp(36px,5vw,54px) clamp(24px,4vw,46px);text-align:center;}
.origin .mid .eyebrow{color:var(--rust);margin-bottom:18px;}
.origin .mid h2{font-family:var(--serif);font-size:clamp(30px,4vw,42px);font-weight:500;line-height:1.08;color:var(--ink);}
.origin .mid h2 em{font-style:italic;color:var(--rust);}
.origin .mid p{font-size:15px;line-height:1.7;color:#4a4239;margin-top:20px;max-width:480px;margin-inline:auto;}
/* Editorial feature grid — base: 3 columns (used at ≤1024px full-width and 640–1024px) */
.origin .proof{display:grid;grid-template-columns:repeat(3,1fr);gap:28px 24px;margin-top:32px;}
.origin .proof .pc{text-align:center;width:auto;max-width:none;border-top:1px solid var(--line);padding-top:16px;}
.origin .proof .pc svg{width:26px;height:26px;color:var(--rust);display:block;margin-inline:auto;}
.origin .proof .pc .pl{font-family:var(--cond);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:600;color:var(--ink);margin-top:10px;line-height:1.3;}
.origin .proof .pc .pd{font-family:var(--sans);font-size:15px;color:var(--ink);opacity:.7;line-height:1.6;margin-top:6px;max-width:none;}
.origin .mid .more{margin-top:34px;}
.origin .strip{background:#15110d;display:flex;flex-direction:column;gap:8px;padding:20px;justify-content:center;}
.origin .strip .sf{overflow:hidden;border-radius:2px;}
.origin .strip .sf img{width:100%;height:100%;object-fit:cover;}
.origin .strip .sf-1{height:90px;}
.origin .strip .sf-2{height:130px;}
.origin .strip .sf-3{height:90px;}
.origin .strip .note{font-family:var(--cond);font-size:11px;color:#d8ccba;text-align:center;letter-spacing:.1em;text-transform:uppercase;margin-top:6px;}

/* ============ FEATURED STORIES ============ */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.feat-card{display:block;text-decoration:none;}
.feat-card .frame{aspect-ratio:5/6;}
.feat-card .frame img{transition:transform .5s ease;}
.feat-card:hover .frame img{transform:scale(1.04);}
.feat-card h3{font-family:var(--cond);letter-spacing:.07em;text-transform:uppercase;color:var(--cream);font-size:15px;font-weight:600;margin-top:16px;line-height:1.25;}
.feat-card p{color:rgba(244,237,226,.75);font-size:13px;line-height:1.55;margin:8px 0 12px;font-weight:300;}
.feat-card .arrow-link{color:var(--terracotta);font-size:11px;}

/* ============ OFFERS ============ */
.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.offer-card{border:1px solid var(--line);padding:28px 26px;display:flex;gap:18px;background:#faf4ea;}
.offer-card .badge{width:54px;height:54px;flex:0 0 54px;border-radius:50%;background:var(--rust);display:flex;align-items:center;justify-content:center;}
.offer-card .badge svg{width:26px;height:26px;color:var(--cream);}
.offer-card h3{font-family:var(--cond);letter-spacing:.06em;text-transform:uppercase;font-size:16px;font-weight:600;color:var(--ink);}
.offer-card .loc{font-size:13px;color:var(--muted);margin-top:4px;font-style:italic;font-family:var(--serif);}
.offer-card p{font-size:13px;color:#4a4239;line-height:1.55;margin:12px 0;}
.offer-card .price{font-family:var(--cond);letter-spacing:.06em;text-transform:uppercase;font-size:13px;font-weight:600;color:var(--ink);}
.offer-card .arrow-link{font-size:11px;margin-top:14px;}
.deposit-note{text-align:center;font-size:12px;color:var(--muted);margin-top:26px;letter-spacing:.04em;line-height:1.6;}
.deposit-note strong{color:var(--rust-deep);}

/* ============ HOW IT WORKS ============ */
.how{position:relative;overflow:hidden;}
.how .firelight{position:absolute;right:0;top:0;width:300px;height:100%;background:linear-gradient(90deg,transparent,rgba(181,80,42,.3),rgba(60,30,15,.6));pointer-events:none;}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr) minmax(200px,220px);gap:22px;align-items:start;position:relative;}
.step .num{width:30px;height:30px;border-radius:50%;background:var(--rust);color:var(--cream);font-family:var(--cond);font-weight:600;display:flex;align-items:center;justify-content:center;font-size:14px;margin-bottom:12px;}
.step h4{font-family:var(--cond);letter-spacing:.1em;text-transform:uppercase;color:var(--cream);font-size:13px;font-weight:600;line-height:1.3;}
.step p{color:rgba(244,237,226,.72);font-size:12.5px;line-height:1.5;margin-top:8px;font-weight:300;}
.how .cta-box{display:flex;flex-direction:column;gap:10px;}
.how .cta-box .dep-line{color:rgba(244,237,226,.6);font-size:11px;line-height:1.5;text-align:center;}

/* ============ SOCIAL PROOF ============ */
.social-grid{display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:24px;align-items:center;}
.social .frame{aspect-ratio:1/1;}
.social .quote-wrap{padding:0 14px;text-align:center;}
.social .qmark{font-family:var(--serif);font-size:64px;color:var(--rust);line-height:.6;}
.social blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2.4vw,21px);line-height:1.45;color:var(--ink);margin:10px 0 18px;}
.social .attr{font-family:var(--cond);letter-spacing:.12em;text-transform:uppercase;font-size:13px;font-weight:600;color:var(--ink);}
.social .twin{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

/* ============ JOURNAL ============ */
.jcard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.jcard-grid--two{grid-template-columns:repeat(2,1fr);max-width:760px;}
.jcard-grid--home .jcard .frame{aspect-ratio:4/3;}
.jcard{display:block;text-decoration:none;}
.jcard .frame{aspect-ratio:4/5;}
.jcard .frame img{transition:transform .5s ease;}
.jcard:hover .frame img{transform:scale(1.04);}
.jcard .cat{font-family:var(--cond);letter-spacing:.14em;text-transform:uppercase;font-size:11px;color:var(--rust);margin-top:14px;display:block;}
.jcard h3{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);margin-top:6px;line-height:1.25;}
.jcard p{font-size:14px;color:#4a4239;line-height:1.6;margin-top:8px;}
.jcard .arrow-link{font-size:11px;margin-top:12px;display:block;}

/* Dark-section jcard overrides (homepage From the Journal) */
.section--dark .jcard h3{color:var(--cream);}
.section--dark .jcard p{color:rgba(244,237,226,.72);}
.section--dark .jcard .cat{color:var(--terracotta);}

/* ============ ARTICLE PAGES ============ */
.article-byline{font-family:var(--cond);letter-spacing:.12em;text-transform:uppercase;font-size:12px;color:var(--muted);margin-bottom:28px;}
.article-body{display:flex;justify-content:center;}
.article-body .prose{width:100%;}
.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--cond);letter-spacing:.12em;text-transform:uppercase;font-size:12px;color:var(--rust);text-decoration:none;margin-top:40px;border-bottom:1px solid transparent;}
.back-link:hover{border-bottom-color:var(--rust);}
.related-head{font-family:var(--serif);font-size:clamp(26px,3.8vw,36px);font-weight:500;margin-bottom:28px;color:var(--ink);}
@media(max-width:640px){.jcard-grid--two{grid-template-columns:1fr;}}

/* ============ FAQ ============ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 50px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-item .q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--cond);letter-spacing:.04em;font-size:16px;font-weight:600;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 0;
}
.faq-item .q .plus{color:var(--rust);font-weight:400;font-size:22px;line-height:1;transition:transform .2s;flex:0 0 auto;}
.faq-item .q[aria-expanded="true"] .plus{transform:rotate(45deg);}
.faq-item .a{font-size:13.5px;color:#4a4239;line-height:1.6;overflow:hidden;max-height:0;transition:max-height .25s ease,padding .25s ease;}
.faq-item .a > div{padding:0 0 16px;}
.faq-item .q[aria-expanded="true"] + .a{max-height:400px;}

/* ============ FINAL CTA ============ */
.final{position:relative;min-height:360px;background:linear-gradient(100deg,#0d0a14,#3a1d14);display:flex;align-items:center;overflow:hidden;}
.final__media{position:absolute;inset:0;z-index:0;}
.final__media img{width:100%;height:100%;object-fit:cover;opacity:.4;}
.final .scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(circle at 70% 50%,rgba(181,80,42,.45),transparent 55%),linear-gradient(100deg,rgba(13,10,20,.85),rgba(58,29,20,.5));}
.final .inner{position:relative;z-index:2;padding:clamp(40px,6vw,60px) 0;max-width:760px;}
.final .eyebrow{color:var(--terracotta);margin-bottom:16px;}
.final h2{font-family:var(--serif);font-size:clamp(38px,6vw,54px);font-weight:500;color:var(--cream);line-height:1.05;}
.final h2 em{font-style:italic;color:var(--terracotta);}
.final p{color:rgba(244,237,226,.85);font-size:15px;line-height:1.6;margin-top:18px;max-width:520px;font-weight:300;}
.final-btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;align-items:center;}
.final .dep-sub{color:rgba(244,237,226,.6);font-size:11px;max-width:200px;line-height:1.5;}

/* ============ FOOTER ============ */
.footer{background:#100c08;color:var(--cream);padding:clamp(40px,6vw,52px) var(--gutter) 26px;}
.foot-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1.2fr .9fr 1fr;gap:34px;}
.footer .brand img{height:38px;}
.footer .tag{font-size:13px;color:rgba(244,237,226,.62);line-height:1.6;margin-top:14px;max-width:230px;font-weight:300;}
.footer .socials{display:flex;gap:12px;margin-top:18px;}
.footer .socials a{width:34px;height:34px;border:1px solid rgba(244,237,226,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.footer .socials a:hover{border-color:var(--terracotta);}
.footer .socials svg{width:15px;height:15px;color:rgba(244,237,226,.75);}
.foot-col h5{font-family:var(--cond);letter-spacing:.16em;text-transform:uppercase;font-size:12px;color:var(--terracotta);margin-bottom:16px;}
.foot-col a{display:block;color:rgba(244,237,226,.72);text-decoration:none;font-size:13px;margin-bottom:9px;font-weight:300;}
.foot-col a:hover{color:var(--cream);}
.foot-cta .frame{height:90px;margin-bottom:14px;}
.foot-cta h5{color:var(--cream);font-family:var(--serif);font-size:18px;text-transform:none;letter-spacing:0;margin-bottom:6px;}
.foot-cta p{font-size:12px;color:rgba(244,237,226,.62);line-height:1.5;margin-bottom:14px;}
.foot-cta .btn{width:100%;margin-bottom:8px;font-size:12px;padding:12px;}
.foot-bottom{max-width:var(--maxw);margin:40px auto 0;border-top:1px solid rgba(244,237,226,.12);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:11px;color:rgba(244,237,226,.5);letter-spacing:.04em;}

/* ============ INTERIOR PAGES ============ */
.page-hero{background:var(--near-black);color:var(--cream);padding:clamp(48px,8vw,90px) 0 clamp(40px,6vw,64px);}
.page-hero .eyebrow{color:var(--terracotta);margin-bottom:14px;}
.page-hero h1{font-family:var(--serif);font-size:clamp(40px,7vw,68px);font-weight:500;line-height:1.04;}
.page-hero h1 em{font-style:italic;color:var(--terracotta);}
.page-hero p{color:rgba(244,237,226,.82);font-size:clamp(15px,2vw,18px);line-height:1.6;max-width:560px;margin-top:20px;font-weight:300;}
.breadcrumbs{font-family:var(--cond);letter-spacing:.1em;text-transform:uppercase;font-size:11px;padding:14px 0;color:var(--muted);}
.breadcrumbs a{color:var(--rust);text-decoration:none;}
.breadcrumbs a:hover{text-decoration:underline;}
.breadcrumbs span{margin:0 8px;color:var(--line);}
.prose{max-width:720px;}
.prose h2{font-family:var(--serif);font-size:clamp(26px,3.4vw,34px);font-weight:500;margin:36px 0 14px;line-height:1.1;}
.prose h3{font-family:var(--cond);letter-spacing:.06em;text-transform:uppercase;font-size:17px;font-weight:600;margin:28px 0 10px;}
.prose p{font-size:16px;line-height:1.75;color:#4a4239;margin-bottom:16px;}
.prose ul{margin:0 0 16px 22px;}
.prose li{font-size:16px;line-height:1.7;color:#4a4239;margin-bottom:8px;}
.prose a{color:var(--rust-deep);}

/* ============ FORMS ============ */
.form-card{background:#faf4ea;border:1px solid var(--line);padding:clamp(24px,4vw,40px);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field.full{grid-column:1/-1;}
.field label{font-family:var(--cond);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:600;color:var(--ink);}
.field .req{color:var(--rust);}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:15px;padding:12px 14px;border:1.5px solid var(--line);
  background:#fff;color:var(--ink);border-radius:0;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--rust);outline:3px solid var(--focus);outline-offset:1px;}
.field textarea{min-height:130px;resize:vertical;}
.field .hint{font-size:12px;color:var(--muted);}
.field .error{font-size:12px;color:var(--rust-deep);font-weight:500;display:none;}
.field.invalid .error{display:block;}
.field.invalid input,.field.invalid textarea,.field.invalid select{border-color:var(--rust-deep);}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:#4a4239;line-height:1.5;}
.consent input{margin-top:3px;flex:0 0 auto;width:auto;}
.hp{position:absolute;left:-9999px;}
.form-tabs{display:flex;gap:0;margin-bottom:26px;border-bottom:1px solid var(--line);flex-wrap:wrap;}
.form-tabs button{
  font-family:var(--cond);letter-spacing:.1em;text-transform:uppercase;font-size:13px;font-weight:600;
  background:none;border:none;border-bottom:2.5px solid transparent;padding:12px 18px;cursor:pointer;color:var(--muted);
}
.form-tabs button[aria-selected="true"]{color:var(--ink);border-bottom-color:var(--rust);}

/* ============ CALLOUT / NOTE BOXES ============ */
.callout{background:#faf4ea;border-left:3px solid var(--rust);padding:20px 24px;margin:24px 0;}
.callout h3{font-family:var(--cond);letter-spacing:.06em;text-transform:uppercase;font-size:14px;color:var(--rust-deep);margin-bottom:8px;}
.callout p{font-size:14px;line-height:1.6;color:#4a4239;}
.callout.dark{background:rgba(181,80,42,.12);border-left-color:var(--terracotta);}

/* template draft banner */
.draft-banner{background:#2a2520;color:#e8dcc8;font-family:var(--cond);letter-spacing:.08em;text-transform:uppercase;font-size:12px;text-align:center;padding:10px;}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .trust .grid{grid-template-columns:repeat(2,1fr);}
  .trust .cell:nth-child(2){border-right:none;}
  .trust .cell:nth-child(1),.trust .cell:nth-child(2){border-bottom:1px solid var(--line);}
  .exp-grid,.feat-grid{grid-template-columns:repeat(2,1fr);}
  .offer-grid{grid-template-columns:1fr;}
  .how-grid{grid-template-columns:repeat(2,1fr);}
  .how .cta-box{grid-column:1/-1;}
  .origin{grid-template-columns:1fr;}
  .origin .photo{min-height:340px;}
  .origin .strip{flex-direction:row;}
  .origin .strip .sf{flex:1;height:120px;}
  .origin .strip .note{display:none;}
  .social-grid{grid-template-columns:1fr;}
  .jcard-grid{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .form-grid{grid-template-columns:1fr;}
}
/* The mobile panel holds a duplicate of nav + CTAs; toggled by .open */
.mobile-panel{display:none;}
@media (max-width:768px){
  .header{flex-wrap:wrap;row-gap:0;}
  .header > .nav,.header > .header-cta{display:none;}
  .menu-toggle{display:inline-flex;}
  .mobile-panel{flex-basis:100%;width:100%;}
  .header.open .mobile-panel{display:block;padding-top:16px;}
  .mobile-panel .nav{display:flex;flex-direction:column;gap:0;}
  .mobile-panel .nav a{padding:12px 0;border-bottom:1px solid var(--line-dark);width:100%;}
  .mobile-panel .header-cta{display:flex;flex-direction:column;padding:14px 0 4px;gap:10px;}
  .mobile-panel .header-cta .btn{width:100%;padding:14px;}

  .faq-grid{grid-template-columns:1fr;}
  .jcard-grid,.exp-grid,.feat-grid,.how-grid{grid-template-columns:1fr;}
  .social .twin{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1fr;}
  .final .dep-sub{max-width:none;}
  .svc-split{grid-template-columns:1fr;}
  .svc-split--img-right .svc-split__img,.svc-split--img-right .svc-split__text{order:unset;}
}

/* ============ SERVICES PAGE — editorial split ============ */
.svc-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;}
.svc-split--img-right .svc-split__img{order:2;}
.svc-split--img-right .svc-split__text{order:1;}
.svc-split .frame{aspect-ratio:4/5;}

/* ============ PROOF GALLERY — service page 3-col grid ============ */
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
@media(max-width:1024px){.proof-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:768px){.proof-grid{grid-template-columns:1fr;}}

/* ============ ACCESSIBLE LIGHTBOX ============ */
.lb{cursor:zoom-in;}
#tlb-backdrop{position:fixed;inset:0;z-index:9000;background:rgba(18,14,11,.93);display:flex;align-items:center;justify-content:center;overscroll-behavior:contain;}
#tlb-backdrop[hidden]{display:none;}
#tlb-inner{position:relative;max-width:min(96vw,1400px);max-height:96dvh;display:flex;align-items:center;justify-content:center;}
#tlb-img{display:block;max-width:100%;max-height:96dvh;width:auto;height:auto;object-fit:contain;}
#tlb-close{position:absolute;top:-44px;right:0;background:none;border:none;color:#fff;font-size:28px;line-height:1;cursor:pointer;padding:6px 10px;opacity:.75;}
#tlb-close:hover,#tlb-close:focus-visible{opacity:1;}
#tlb-prev,#tlb-next{position:fixed;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:36px;line-height:1;cursor:pointer;padding:12px 18px;opacity:.6;z-index:9001;}
#tlb-prev{left:0;}#tlb-next{right:0;}
#tlb-prev:hover,#tlb-prev:focus-visible,#tlb-next:hover,#tlb-next:focus-visible{opacity:1;}
@media(max-width:600px){#tlb-prev,#tlb-next{font-size:26px;padding:10px 12px;}}

/* ============ PROJECT GALLERY — uniform square grid ============ */
/* Used on all portfolio project pages. 3 col → 2 col → 1 col.  */
.project-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  max-width:1500px;
  margin:0 auto;
  padding:0 20px 48px;
}
.project-gallery__item{
  display:block;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--charcoal);
  cursor:zoom-in;
}
.project-gallery__item:focus-visible{
  outline:2px solid var(--rust);
  outline-offset:3px;
}
.project-gallery__image{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
@media(prefers-reduced-motion:no-preference){
  .project-gallery__image{transition:transform 250ms ease;}
  .project-gallery__item:hover .project-gallery__image{transform:scale(1.03) translateY(-1px);}
  .project-gallery__item:focus-visible .project-gallery__image{transform:scale(1.03);}
}
@media(prefers-reduced-motion:reduce){
  .project-gallery__image{transition:none;}
}
@media(max-width:1080px){
  .project-gallery{grid-template-columns:repeat(2,1fr);gap:16px;}
}
@media(max-width:560px){
  .project-gallery{grid-template-columns:1fr;gap:14px;padding:0 16px 40px;}
}

/* Project intro — light-background title section replacing dark hero */
.proj-intro-title{
  font-family:var(--serif);
  font-size:clamp(36px,6vw,60px);
  font-weight:500;
  line-height:1.06;
  color:var(--ink);
  margin-bottom:8px;
}
.proj-intro-title em{font-style:italic;color:var(--rust);}
.proj-intro-meta{
  font-family:var(--cond);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:12px;
  color:var(--muted);
  margin-top:10px;
  font-weight:400;
}
.proj-intro-hook{
  color:var(--ink);
  font-size:clamp(15px,2vw,17px);
  line-height:1.65;
  max-width:560px;
  margin-top:14px;
  font-weight:300;
  opacity:.8;
}
/* Project prev/next navigation */
.proj-nav{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:32px 0 8px;border-top:1px solid var(--line);flex-wrap:wrap;}
.proj-nav a{font-family:var(--cond);letter-spacing:.12em;text-transform:uppercase;font-size:12px;color:var(--rust);text-decoration:none;}
.proj-nav a:hover{color:var(--rust-deep);}

/* ============================================================
   GEO / AI CITABILITY UPDATE — June 2026
   New utility classes: .page-summary, .credentials-glance,
   .author-box, .fact-block, .editorial-credit
   ============================================================ */

/* Page summary — factual lede appearing near top of each page */
.page-summary {
  font-family: var(--sans);
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 1.72;
  color: var(--ink);
  opacity: .82;
  max-width: 720px;
  border-left: 2px solid var(--rust);
  padding: 0 0 0 20px;
  margin: 0 0 28px;
}
.page-summary--light {
  color: var(--cream);
  opacity: .85;
  border-left-color: var(--terracotta);
}

/* Fact block — structured summary at top of journal articles */
.fact-block {
  background: rgba(90,56,40,.06);
  border: 1px solid rgba(90,56,40,.14);
  border-radius: 3px;
  padding: clamp(16px,3vw,24px) clamp(18px,3vw,28px);
  margin: 0 0 32px;
}
.fact-block__label {
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--rust);
  font-weight: 600;
  margin-bottom: 10px;
}
.fact-block p {
  font-size: 14px;
  line-height: 1.68;
  color: var(--ink);
  margin: 0 0 6px;
}
.fact-block p:last-child { margin-bottom: 0; }
.fact-block a { color: var(--rust-deep); text-decoration: underline; text-underline-offset: 2px; }

/* Credentials at a glance — definition list */
.credentials-glance {
  background: rgba(90,56,40,.05);
  border-radius: 4px;
  padding: clamp(20px,3.5vw,32px);
  margin: 28px 0;
}
.credentials-glance__heading {
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--rust);
  font-weight: 600;
  margin: 0 0 18px;
}
.credentials-glance dl {
  display: grid;
  grid-template-columns: minmax(140px, 210px) 1fr;
  gap: 10px 20px;
  margin: 0;
}
@media(max-width:560px) {
  .credentials-glance dl { grid-template-columns: 1fr; gap: 4px 0; }
  .credentials-glance dt { margin-top: 12px; }
}
.credentials-glance dt {
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
  opacity: .65;
  padding-top: 1px;
}
.credentials-glance dd {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0;
}
.credentials-glance dd a { color: var(--rust-deep); text-decoration: underline; text-underline-offset: 2px; }
.credentials-glance__footer {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 13px;
  color: var(--muted);
}
.credentials-glance__footer a { color: var(--rust-deep); }

/* Editorial credit — small inline credibility element */
.editorial-credit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid rgba(90,56,40,.25);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.editorial-credit:hover { color: var(--rust-deep); border-color: var(--rust); }
.editorial-credit__dot { width: 4px; height: 4px; border-radius: 50%; background: var(--rust); flex-shrink: 0; }

/* Author box — at end of journal articles */
.author-box {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  margin-top: 40px;
}
.author-box__text {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.68;
  color: var(--ink);
  opacity: .82;
}
.author-box__text strong { font-weight: 600; opacity: 1; }
.author-box__text a { color: var(--rust-deep); text-decoration: underline; text-underline-offset: 2px; }

/* Article meta (date/category/reading time) */
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  margin: 12px 0 24px;
}
.article-meta__item {
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}
.article-meta__sep { color: var(--line); }
.article-meta time { color: var(--muted); }

/* Journal card date display */
.jcard-date {
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 4px 0 6px;
  display: block;
}

/* Colorado planning facts sourced section */
.sourced-facts {
  background: rgba(90,56,40,.04);
  border-radius: 4px;
  padding: clamp(24px,4vw,40px);
  margin: 0;
}
.sourced-facts__disclaimer {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
  font-size: 12px;
  color: var(--muted);
  line-height: 1.6;
}
.sourced-facts ol {
  margin: 14px 0 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.sourced-facts li { font-size: 15px; line-height: 1.7; color: var(--ink); }
.sourced-facts li strong { font-weight: 600; }
.sourced-facts li a { color: var(--rust-deep); text-underline-offset: 2px; }
.sourced-facts cite {
  display: block;
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 4px;
  font-style: normal;
}

/* Press credentials page */
.press-table { width: 100%; border-collapse: collapse; margin: 16px 0 0; }
.press-table th {
  font-family: var(--cond);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  text-align: left;
  padding: 8px 12px;
  border-bottom: 2px solid var(--line);
}
.press-table td {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink);
  padding: 14px 12px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.press-table td a { color: var(--rust-deep); text-decoration: underline; text-underline-offset: 2px; }
.press-table tr:last-child td { border-bottom: none; }

/* Areas of Work grid on press page */
.areas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 20px;
  margin: 20px 0 0;
}
.area-card {
  background: rgba(90,56,40,.05);
  border-radius: 3px;
  padding: 20px 22px;
}
.area-card h4 {
  font-family: var(--cond);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--rust);
  margin: 0 0 8px;
  font-weight: 600;
}
.area-card p { font-size: 14px; line-height: 1.6; color: var(--ink); margin: 0 0 10px; }
.area-card a { font-size: 13px; color: var(--rust-deep); text-decoration: underline; text-underline-offset: 2px; }

/* ============ WEB DESIGN SECTIONS ============ */

/* Process steps — 4-column row */
.web-process { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,32px); margin:32px 0 0; }
.web-process-step { display:flex; flex-direction:column; }
.web-process-step .step-num { font-family:var(--cond); font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--rust); margin-bottom:10px; }
.web-process-step h4 { font-family:var(--cond); font-size:15px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--ink); margin-bottom:8px; line-height:1.3; }
.web-process-step p { font-size:14px; line-height:1.7; color:#4a4239; margin:0; }

@media (max-width:860px) { .web-process { grid-template-columns:1fr 1fr; gap:22px; } }
@media (max-width:560px) { .web-process { grid-template-columns:1fr; gap:20px; } }

/* Web project cards grid */
.web-project-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,32px); margin-top:32px; }
.web-project-card { background:#faf4ea; border:1px solid var(--line); display:flex; flex-direction:column; overflow:hidden; }
.web-project-card__img { aspect-ratio:16/10; overflow:hidden; background:var(--near-black); flex:0 0 auto; }
.web-project-card__img img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; transition:transform .45s ease; }
.web-project-card:hover .web-project-card__img img { transform:scale(1.03); }
.web-project-card__body { padding:clamp(22px,3.5vw,32px); display:flex; flex-direction:column; flex:1; }
.web-project-card .project-label { font-family:var(--cond); font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--rust); margin-bottom:14px; }
.web-project-card h3 { font-family:var(--serif); font-size:clamp(20px,2.4vw,26px); font-weight:500; color:var(--ink); line-height:1.15; margin-bottom:4px; }
.web-project-card .project-industry { font-family:var(--cond); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:16px; }
.web-project-card p { font-size:15px; line-height:1.72; color:#4a4239; margin-bottom:16px; }
.web-project-card .project-services { font-family:var(--cond); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink); opacity:.7; line-height:1.7; margin-bottom:20px; }
.web-project-card .project-services strong { color:var(--ink); opacity:1; font-weight:600; display:block; margin-bottom:3px; }
.web-project-card .project-link { margin-top:auto; display:inline-flex; align-items:center; gap:7px; font-family:var(--cond); font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--rust-deep); text-decoration:none; border-bottom:1px solid transparent; transition:border-color .18s; }
.web-project-card .project-link:hover { border-bottom-color:var(--rust-deep); }
.web-project-card .project-link svg { width:14px; height:14px; flex:0 0 14px; }

@media (max-width:720px) { .web-project-grid { grid-template-columns:1fr; } }

/* ============ ORIGIN PROOF GRID — responsive overrides ============ */
/* Large desktop ≥1200px: 3-above-2 centered editorial layout using a 6-column track grid */
@media (min-width:1200px) {
  .origin .proof {
    grid-template-columns: repeat(6,1fr);
    gap: 30px 20px;
  }
  .origin .proof .pc:nth-child(1){grid-column:1/3;}
  .origin .proof .pc:nth-child(2){grid-column:3/5;}
  .origin .proof .pc:nth-child(3){grid-column:5/7;}
  .origin .proof .pc:nth-child(4){grid-column:2/4;}
  .origin .proof .pc:nth-child(5){grid-column:4/6;}
}
/* Laptop 1025–1199px: origin still 3-col layout but mid is narrower — use 2-col proof */
@media (min-width:1025px) and (max-width:1199px) {
  .origin .proof {
    grid-template-columns: repeat(2,1fr);
    gap: 26px 24px;
  }
}
/* Tablet ≤768px: 2-col proof */
@media (max-width:768px) {
  .origin .proof {
    grid-template-columns: repeat(2,1fr);
    gap: 22px 18px;
  }
  .origin .proof .pc .pd { font-size: 15px; }
}
/* Mobile ≤560px: single-column */
@media (max-width:560px) {
  .origin .proof {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
