/* Tindle & Roe — Buttermilk Grove (espresso + teal) */
:root{
  --espresso:#5C3A21; --clay:#A9764A; --teal:#0E7C7B;
  --bg:#FBF4E6; --fg:#2A2018;
  --teal-d:#0a5f5e; --teal-soft:rgba(14,124,123,.10);
  --paper:#fffaf0; --line:rgba(92,58,33,.16);
  --shadow:0 18px 50px -28px rgba(42,32,24,.45);
  --shadow-sm:0 8px 24px -16px rgba(42,32,24,.4);
  --r:14px; --r-lg:22px; --maxw:1160px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--fg);
  font-family:"Hind Madurai",system-ui,sans-serif; font-size:18px; line-height:1.7;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  background-image:
    radial-gradient(60rem 40rem at 85% -8%, rgba(14,124,123,.07), transparent 60%),
    radial-gradient(48rem 36rem at -8% 12%, rgba(169,118,74,.10), transparent 60%);
  background-attachment:fixed;
}
h1,h2,h3,h4{font-family:"Grandstander","Hind Madurai",sans-serif; line-height:1.08; color:var(--espresso); margin:0 0 .5em; font-weight:700; letter-spacing:-.01em}
p{margin:0 0 1em}
a{color:var(--teal-d); text-decoration-thickness:1.5px; text-underline-offset:3px}
a:hover{color:var(--teal)}
img{max-width:100%; height:auto; display:block}
code,kbd,.mono{font-family:"Lekton",monospace}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.skip{position:absolute; left:12px; top:-60px; background:var(--teal); color:#fff; padding:12px 18px; border-radius:10px; z-index:200; transition:top .2s; font-weight:600}
.skip:focus{top:12px; color:#fff}
:focus-visible{outline:3px solid var(--teal); outline-offset:3px; border-radius:6px}

/* cursor blob */
.cursor-blob{position:fixed; top:0; left:0; width:540px; height:540px; margin:-270px 0 0 -270px; pointer-events:none; z-index:0;
  background:radial-gradient(circle, rgba(14,124,123,.16), rgba(14,124,123,.05) 45%, transparent 70%);
  will-change:transform; opacity:0; transition:opacity .6s}
.blob-on .cursor-blob{opacity:1}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:.5em; background:var(--teal); color:#fff; border:0;
  padding:15px 26px; border-radius:999px; font:600 16px/1 "Hind Madurai",sans-serif; cursor:pointer;
  text-decoration:none; box-shadow:var(--shadow-sm); transition:transform .25s var(--ease), background .2s, box-shadow .25s}
.btn:hover{background:var(--teal-d); color:#fff; transform:translateY(-2px); box-shadow:0 16px 34px -18px rgba(14,124,123,.7)}
.btn svg{transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-sm{padding:11px 18px; font-size:14.5px}
.btn-ghost{background:transparent; color:var(--espresso); box-shadow:none; border:1.5px solid var(--line)}
.btn-ghost:hover{background:var(--teal-soft); color:var(--teal-d); border-color:transparent; box-shadow:none}

/* header */
.site-head{position:sticky; top:0; z-index:100; backdrop-filter:saturate(1.4) blur(10px);
  background:rgba(251,244,230,.82); border-bottom:1px solid var(--line)}
.head-in{display:flex; align-items:center; gap:18px; padding-top:14px; padding-bottom:14px}
.brand{display:inline-flex; align-items:center; gap:10px; text-decoration:none; color:var(--espresso); font-weight:700}
.brand-mark{display:grid; place-items:center; width:40px; height:40px; border-radius:12px; background:var(--teal-soft); color:var(--teal-d)}
.brand-name{font-family:"Grandstander",sans-serif; font-size:21px; letter-spacing:-.01em}
.brand-name .amp{color:var(--clay)}
.nav{margin-left:auto; display:flex; gap:6px}
.nav a{padding:9px 14px; border-radius:999px; text-decoration:none; color:var(--fg); font-weight:600; font-size:15.5px; transition:background .2s,color .2s}
.nav a:hover{background:var(--teal-soft); color:var(--teal-d)}
.nav a[aria-current=page]{color:var(--teal-d); background:var(--teal-soft)}
.head-in>.btn{flex:none}

/* eyebrow */
.eyebrow{display:inline-flex; align-items:center; gap:9px; font:700 12.5px/1 "Hind Madurai",sans-serif;
  letter-spacing:.18em; text-transform:uppercase; color:var(--teal-d); margin:0 0 18px}
.eyebrow::before{content:""; width:26px; height:2px; background:var(--clay); border-radius:2px}

/* hero */
.hero{position:relative; z-index:1; padding:72px 0 88px}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center}
.hero h1{font-size:clamp(2.6rem,5.6vw,4.3rem); font-weight:800; margin-bottom:.32em}
.hero h1 .em{color:var(--teal-d)}
.hero .lede{font-size:1.22rem; max-width:30ch; color:#4a3b2d}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-top:30px}
.hero-media{position:relative}
.hero-media .frame{border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line)}
.hero-media img{width:100%; aspect-ratio:1024/640; object-fit:cover}
.hero-badge{position:absolute; left:-22px; bottom:26px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r); padding:15px 18px; box-shadow:var(--shadow); display:flex; gap:12px; align-items:center; max-width:240px}
.hero-badge .b-ic{display:grid; place-items:center; width:42px; height:42px; border-radius:12px; background:var(--teal-soft); color:var(--teal-d); flex:none}
.hero-badge strong{font-family:"Grandstander",sans-serif; display:block; color:var(--espresso); font-size:15px}
.hero-badge span{font-size:13.5px; color:#5a4a3a; line-height:1.4}

/* trust strip */
.trust{border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:rgba(255,250,240,.6)}
.trust-in{display:flex; flex-wrap:wrap; gap:14px 34px; align-items:center; justify-content:center; padding:20px 24px;
  font-family:"Lekton",monospace; font-size:15px; color:#5a4a3a; letter-spacing:.02em}
.trust-in span{display:inline-flex; align-items:center; gap:9px}
.trust-in .dot{width:6px; height:6px; border-radius:50%; background:var(--clay)}

/* sections */
section{position:relative; z-index:1}
.band{padding:84px 0}
.band-paper{background:linear-gradient(180deg,transparent,rgba(255,250,240,.7)); }
.sec-head{max-width:62ch; margin-bottom:46px}
.sec-head.center{margin-left:auto; margin-right:auto; text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem)}
.sec-head p{font-size:1.12rem; color:#4a3b2d}

/* feature cards */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s}
.card:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
.card .ico{display:grid; place-items:center; width:54px; height:54px; border-radius:15px; background:var(--teal-soft); color:var(--teal-d); margin-bottom:18px}
.card h3{font-size:1.32rem; margin-bottom:.35em}
.card p{color:#4a3b2d; font-size:1rem; margin-bottom:0}
.card .step{margin-top:16px; padding-top:16px; border-top:1px solid var(--line); display:flex; gap:10px; align-items:flex-start;
  font-family:"Lekton",monospace; font-size:14.5px; color:var(--teal-d)}
.card .step svg{flex:none; margin-top:2px}

/* split */
.split{display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center}
.split.flip .split-media{order:2}
.split-media{border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line)}
.split-media img{width:100%; aspect-ratio:16/10; object-fit:cover}
.checklist{list-style:none; padding:0; margin:22px 0 0; display:grid; gap:13px}
.checklist li{display:flex; gap:12px; align-items:flex-start}
.checklist .ck{display:grid; place-items:center; width:26px; height:26px; border-radius:8px; background:var(--teal-soft); color:var(--teal-d); flex:none; margin-top:2px}
.checklist strong{color:var(--espresso); font-family:"Grandstander",sans-serif}

/* stats */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.stat{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:28px 24px; text-align:center; box-shadow:var(--shadow-sm)}
.stat .num{font-family:"Grandstander",sans-serif; font-weight:800; font-size:2.7rem; color:var(--teal-d); line-height:1; letter-spacing:-.02em}
.stat .lbl{font-size:.96rem; color:#4a3b2d; margin-top:8px}

/* journal */
.journal-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:26px}
.j-card{display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), box-shadow .35s}
.j-card:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
.j-card .j-img{aspect-ratio:16/9; overflow:hidden}
.j-card .j-img img{width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease)}
.j-card:hover .j-img img{transform:scale(1.05)}
.j-body{padding:26px; display:flex; flex-direction:column; flex:1}
.j-meta{display:flex; gap:14px; align-items:center; font-family:"Lekton",monospace; font-size:13.5px; color:var(--clay); margin-bottom:12px; flex-wrap:wrap}
.j-pill{background:var(--teal-soft); color:var(--teal-d); padding:3px 11px; border-radius:999px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; font-size:11.5px; font-family:"Hind Madurai",sans-serif}
.j-card h3{font-size:1.4rem}
.j-card h3 a{color:var(--espresso); text-decoration:none}
.j-card h3 a:hover{color:var(--teal-d)}
.j-card p{color:#4a3b2d; font-size:1rem}
.j-more{margin-top:auto; padding-top:14px; display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--teal-d); text-decoration:none}
.j-more:hover{gap:12px}

/* testimonials */
.tg{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.tcard{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column}
.tcard .q-ic{color:var(--teal); opacity:.5; margin-bottom:8px}
.tcard .stars{display:flex; gap:3px; color:var(--clay); margin-bottom:14px}
.tcard blockquote{margin:0 0 20px; font-size:1.06rem; color:#3a2d20}
.tcard .who{margin-top:auto; display:flex; gap:12px; align-items:center}
.tcard .av{width:44px; height:44px; border-radius:50%; background:var(--teal-soft); color:var(--teal-d); display:grid; place-items:center; font-family:"Grandstander",sans-serif; font-weight:700; flex:none}
.tcard .who strong{display:block; color:var(--espresso); font-family:"Grandstander",sans-serif; font-size:1rem}
.tcard .who span{font-size:.88rem; color:#6a5a4a}

/* resources blogroll */
.blogroll{display:grid; gap:14px}
.blogroll a.res{display:flex; align-items:center; gap:14px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r); padding:18px 22px; text-decoration:none; color:var(--espresso); box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease), box-shadow .25s, border-color .2s}
.blogroll a.res:hover{transform:translateX(5px); border-color:var(--teal); box-shadow:var(--shadow)}
.blogroll .res .r-ic{display:grid; place-items:center; width:44px; height:44px; border-radius:12px; background:var(--teal-soft); color:var(--teal-d); flex:none}
.blogroll .res .r-tx{flex:1}
.blogroll .res strong{font-family:"Grandstander",sans-serif; display:block}
.blogroll .res span{font-size:.9rem; color:#6a5a4a; font-family:"Lekton",monospace}
.blogroll .res .arr{color:var(--teal-d)}

/* CTA band */
.cta{position:relative; overflow:hidden; border-radius:28px; padding:60px; color:#fff;
  background:linear-gradient(135deg,var(--teal-d),var(--teal) 55%,#13908e); box-shadow:var(--shadow)}
.cta::after{content:""; position:absolute; inset:0; background:radial-gradient(30rem 18rem at 90% 10%, rgba(255,255,255,.16), transparent 60%); pointer-events:none}
.cta h2{color:#fff; font-size:clamp(2rem,3.6vw,2.8rem); position:relative}
.cta p{color:rgba(255,255,255,.92); max-width:52ch; position:relative; font-size:1.12rem}
.cta .btn{background:#fff; color:var(--teal-d); position:relative}
.cta .btn:hover{background:var(--bg); color:var(--teal-d)}

/* page hero (inner) */
.phead{padding:62px 0 34px; position:relative; z-index:1}
.phead h1{font-size:clamp(2.3rem,4.6vw,3.5rem); font-weight:800; max-width:18ch}
.phead .lede{font-size:1.18rem; max-width:60ch; color:#4a3b2d}
.crumb{font-family:"Lekton",monospace; font-size:13.5px; color:var(--clay); margin-bottom:14px}
.crumb a{color:var(--clay); text-decoration:none}
.crumb a:hover{color:var(--teal-d)}

/* team */
.team{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.member{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; box-shadow:var(--shadow-sm); text-align:center}
.member .av{width:78px; height:78px; border-radius:50%; margin:0 auto 16px; background:linear-gradient(135deg,var(--teal-soft),rgba(169,118,74,.18));
  color:var(--teal-d); display:grid; place-items:center; font-family:"Grandstander",sans-serif; font-weight:800; font-size:1.5rem}
.member h3{font-size:1.25rem; margin-bottom:2px}
.member .role{font-family:"Lekton",monospace; font-size:13.5px; color:var(--teal-d); margin-bottom:12px}
.member p{font-size:.96rem; color:#4a3b2d; margin-bottom:0}

/* service rows */
.srv{display:grid; gap:20px}
.srv-row{display:grid; grid-template-columns:auto 1fr auto; gap:24px; align-items:flex-start; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow-sm); transition:box-shadow .3s,transform .3s var(--ease)}
.srv-row:hover{box-shadow:var(--shadow); transform:translateY(-3px)}
.srv-row .s-ic{display:grid; place-items:center; width:58px; height:58px; border-radius:16px; background:var(--teal-soft); color:var(--teal-d); flex:none}
.srv-row h3{font-size:1.4rem; margin-bottom:.3em}
.srv-row p{margin-bottom:0; color:#4a3b2d}
.srv-row .s-tags{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px}
.srv-row .s-tags span{font-family:"Lekton",monospace; font-size:13px; background:var(--bg); border:1px solid var(--line); padding:5px 12px; border-radius:999px; color:#5a4a3a}
.srv-row .price{font-family:"Grandstander",sans-serif; font-weight:700; color:var(--teal-d); white-space:nowrap; font-size:1.05rem}

/* contact */
.contact-grid{display:grid; grid-template-columns:1fr 1.05fr; gap:48px; align-items:start}
.cinfo-list{list-style:none; padding:0; margin:24px 0 0; display:grid; gap:18px}
.cinfo-list li{display:flex; gap:14px; align-items:flex-start}
.cinfo-list .ci{display:grid; place-items:center; width:46px; height:46px; border-radius:13px; background:var(--teal-soft); color:var(--teal-d); flex:none}
.cinfo-list strong{display:block; color:var(--espresso); font-family:"Grandstander",sans-serif}
.cinfo-list a{color:var(--teal-d)}
.form-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:34px; box-shadow:var(--shadow)}
.field{margin-bottom:20px}
.field label{display:block; font-weight:600; color:var(--espresso); margin-bottom:7px; font-size:.98rem}
.field input,.field textarea{width:100%; padding:14px 16px; border:1.5px solid var(--line); border-radius:12px; background:var(--bg);
  font:inherit; color:var(--fg); transition:border-color .2s, box-shadow .2s}
.field input::placeholder,.field textarea::placeholder{color:#8a7a68}
.field input:focus,.field textarea:focus{outline:none; border-color:var(--teal); box-shadow:0 0 0 3px var(--teal-soft)}
.field textarea{min-height:140px; resize:vertical}
.form-card .btn{width:100%; justify-content:center; font-size:17px}
.form-note{font-size:.85rem; color:#6a5a4a; margin:14px 0 0; text-align:center; font-family:"Lekton",monospace}
.thanks{display:none; background:var(--teal-soft); border:1px solid var(--teal); border-radius:var(--r); padding:18px 20px; color:var(--teal-d); margin-bottom:20px; font-weight:600}
.thanks.show{display:flex; gap:10px; align-items:center}

/* article */
.article-wrap{display:grid; grid-template-columns:minmax(0,1fr) 280px; gap:50px; align-items:start; padding-bottom:30px}
.article{max-width:68ch}
.article-hero{border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); margin-bottom:38px}
.article-hero img{width:100%; aspect-ratio:16/8; object-fit:cover}
.article h2{font-size:1.7rem; margin-top:1.7em; color:var(--espresso)}
.article h3{font-size:1.28rem; margin-top:1.4em; color:var(--espresso)}
.article p{font-size:1.06rem; line-height:1.75; color:#33271c; max-width:65ch}
.article ul,.article ol{padding-left:1.3em; margin:0 0 1.2em; max-width:64ch}
.article li{margin-bottom:.5em; line-height:1.7}
.article a{color:var(--teal-d); font-weight:600}
.article img{border-radius:var(--r); margin:1.6em 0; box-shadow:var(--shadow-sm); border:1px solid var(--line)}
.article section{margin-top:2em; border-top:1px solid var(--line); padding-top:1.4em}
.article [itemprop=name]{font-size:1.15rem; color:var(--espresso); margin-top:1.3em}
.article [itemprop=text]{color:#33271c}
.aside{position:sticky; top:96px; display:grid; gap:18px}
.aside-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-sm)}
.aside-card h2{font-size:1.05rem; font-family:"Hind Madurai",sans-serif; text-transform:uppercase; letter-spacing:.12em; font-size:.8rem; color:var(--teal-d); margin-bottom:14px}
.aside-card .res{display:flex; gap:11px; align-items:center; text-decoration:none; color:var(--espresso); font-weight:600; padding:8px 0}
.aside-card .res:hover{color:var(--teal-d)}
.aside-card .res svg{color:var(--teal-d); flex:none}
.aside-meta li{display:flex; gap:10px; align-items:center; padding:6px 0; color:#4a3b2d; font-size:.95rem}
.aside-meta{list-style:none; padding:0; margin:0}
.aside-meta svg{color:var(--teal-d); flex:none}

/* reveal */
.reveal{opacity:0; transform:translateY(26px)}
.reveal.in{opacity:1; transform:none; transition:opacity .7s var(--ease), transform .8s var(--ease)}
.reveal.d1{transition-delay:.08s} .reveal.d2{transition-delay:.16s} .reveal.d3{transition-delay:.24s}

/* footer */
.site-foot{position:relative; z-index:1; margin-top:90px; border-top:1px solid var(--line); background:rgba(255,250,240,.6); padding:60px 0 34px}
.foot-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px}
.foot-brand p{max-width:42ch; color:#4a3b2d; margin-top:14px; font-size:.98rem}
.foot-col h2{font-family:"Hind Madurai",sans-serif; font-size:.82rem; text-transform:uppercase; letter-spacing:.14em; color:var(--teal-d); margin-bottom:14px}
.foot-col a{display:block; color:var(--fg); text-decoration:none; padding:5px 0; font-size:.98rem}
.foot-col a:hover{color:var(--teal-d)}
.foot-addr{color:#6a5a4a; font-family:"Lekton",monospace; font-size:.9rem; margin-top:10px}
.foot-base{display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:40px; padding-top:22px; border-top:1px solid var(--line);
  font-family:"Lekton",monospace; font-size:.86rem; color:#6a5a4a}
.foot-base p{margin:0}

/* responsive */
@media(max-width:920px){
  .hero-grid,.split,.contact-grid,.article-wrap{grid-template-columns:1fr}
  .split.flip .split-media{order:0}
  .cards,.tg,.team{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .journal-grid{grid-template-columns:1fr}
  .hero-media{order:-1}
  .aside{position:static}
  .article{max-width:none}
  .nav{display:none}
}
@media(max-width:600px){
  body{font-size:17px}
  .cards,.tg,.team,.stats{grid-template-columns:1fr}
  .head-in>.btn{display:none}
  .cta{padding:38px 26px}
  .srv-row{grid-template-columns:1fr; gap:14px}
  .hero-badge{left:0}
  .band{padding:60px 0}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important; transition:none!important; scroll-behavior:auto!important}
  .reveal{opacity:1!important; transform:none!important}
  .cursor-blob{display:none!important}
}
@media(prefers-reduced-transparency:reduce){
  .site-head{background:var(--bg); backdrop-filter:none}
  .cursor-blob{display:none!important}
}
@media(hover:none){ .cursor-blob{display:none!important} }
