/* =========================================================================
   Turkey Leg Hut — premium theme styles. Mobile-first.
   ========================================================================= */

:root{
	--bg:#0c0a09;
	--bg-2:#15110e;
	--bg-3:#1d1712;
	--accent:#e8451e;
	--accent-2:#f0a52e;
	--cream:#f6efe3;
	--text:#ece3d6;
	--muted:#a99c8c;
	--line:rgba(255,255,255,.10);
	--serif:'Playfair Display',Georgia,'Times New Roman',serif;
	--sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
	--pad:clamp(40px,8vw,100px);
	--gutter:clamp(18px,5vw,56px);
	--maxw:1240px;
	--r:14px;
	--ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);font-size:17px;line-height:1.7;font-weight:400;overflow-x:hidden}
body.tlh-has-actionbar{padding-bottom:60px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:800;line-height:1.06;color:var(--cream);margin:0 0 .4em;letter-spacing:-.01em}
p{margin:0 0 1em}
::selection{background:var(--accent);color:#fff}

/* Skip link */
.tlh-skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:12px 18px;z-index:200}
.tlh-skip:focus{left:8px;top:8px}

/* ---- Shared bits ----------------------------------------------------- */
.tlh-kicker{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-2);margin:0 0 14px}
.tlh-section{padding:var(--pad) var(--gutter);max-width:var(--maxw);margin:0 auto}
.tlh-sec-head{max-width:760px;margin:0 auto clamp(36px,6vw,64px);text-align:center}
.tlh-sec-title{font-size:clamp(30px,5.2vw,52px)}
.tlh-sec-intro{color:var(--muted);font-size:clamp(16px,2.2vw,19px);margin:0}
.tlh-center{text-align:center}

/* Buttons */
.tlh-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.02em;padding:14px 26px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:all .3s var(--ease);min-height:48px;text-align:center}
.tlh-btn-lg{padding:17px 34px;font-size:16px}
.tlh-btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px 24px -8px rgba(232,69,30,.7)}
.tlh-btn-accent:hover{transform:translateY(-2px);box-shadow:0 14px 34px -8px rgba(232,69,30,.8);filter:brightness(1.06)}
.tlh-btn-outline{border-color:rgba(246,239,227,.35);color:var(--cream)}
.tlh-btn-outline:hover{border-color:var(--cream);background:rgba(246,239,227,.08)}
.tlh-btn-ghost{background:rgba(255,255,255,.06);color:var(--cream)}
.tlh-btn-ghost:hover{background:rgba(255,255,255,.14)}

.tlh-link-arrow{display:inline-block;margin-top:8px;font-weight:600;color:var(--accent-2);border-bottom:1px solid transparent}
.tlh-link-arrow:hover{border-color:var(--accent-2)}

/* =========================================================================
   Header / Nav
   ========================================================================= */
.tlh-brand{display:flex;align-items:center;gap:12px;z-index:95}
.tlh-brand img{width:46px;height:46px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 2px rgba(255,255,255,.08)}
.tlh-brand-txt{font-family:var(--serif);font-weight:800;font-size:20px;color:var(--cream);letter-spacing:.01em}
.tlh-nav-desktop{display:none;align-items:center;gap:30px}
.tlh-menu{display:flex;gap:28px;list-style:none;margin:0;padding:0}
.tlh-menu a{font-size:14.5px;font-weight:500;color:var(--cream);opacity:.9;position:relative;padding:4px 0}
.tlh-menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:width .3s var(--ease)}
.tlh-menu a:hover{opacity:1}
.tlh-menu a:hover::after,.tlh-menu .current-menu-item a::after{width:100%}
.tlh-nav-cta{padding:11px 22px;min-height:auto}

/* Burger */
.tlh-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:48px;height:48px;background:none;border:0;cursor:pointer;z-index:95;padding:10px}
.tlh-burger span{display:block;height:2px;width:26px;background:var(--cream);border-radius:2px;transition:transform .3s var(--ease),opacity .3s var(--ease)}
body.tlh-nav-open .tlh-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.tlh-nav-open .tlh-burger span:nth-child(2){opacity:0}
body.tlh-nav-open .tlh-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile overlay */
.tlh-overlay{position:fixed;inset:0;z-index:92;background:linear-gradient(160deg,#140f0c,#0a0807);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s var(--ease)}
body.tlh-nav-open .tlh-overlay{opacity:1;visibility:visible}
.tlh-overlay-inner{text-align:center;padding:30px;width:100%;max-width:480px}
.tlh-overlay-menu{list-style:none;margin:0 0 36px;padding:0;display:flex;flex-direction:column;gap:6px}
.tlh-overlay-menu a{font-family:var(--serif);font-size:30px;font-weight:700;color:var(--cream);display:block;padding:10px;transition:color .3s var(--ease),transform .3s var(--ease)}
.tlh-overlay-menu a:hover{color:var(--accent);transform:translateX(4px)}
.tlh-overlay-foot{display:flex;flex-direction:column;gap:12px;align-items:center;border-top:1px solid var(--line);padding-top:28px}
.tlh-overlay-foot .tlh-btn{width:100%;max-width:300px}
.tlh-status{font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.tlh-status.is-open{color:#5ad17a}.tlh-status.is-closed{color:var(--muted)}

/* =========================================================================
   Hero
   ========================================================================= */
.tlh-hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;background-size:cover;background-position:center;padding:120px var(--gutter) clamp(56px,10vh,90px)}
.tlh-hero-inner{position:relative;max-width:var(--maxw);width:100%;margin:0 auto}
.tlh-hero-title{font-size:clamp(38px,9vw,82px);font-weight:900;max-width:14ch;text-shadow:0 2px 40px rgba(0,0,0,.5)}
.tlh-hero-sub{color:var(--cream);opacity:.92;font-size:clamp(16px,2.4vw,21px);max-width:54ch;margin:.4em 0 0}
.tlh-hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.tlh-hero-status{display:flex;align-items:center;gap:9px;margin:22px 0 0;font-size:14px;font-weight:600;color:var(--cream)}
.tlh-dot{width:9px;height:9px;border-radius:50%;background:var(--muted);box-shadow:0 0 0 4px rgba(255,255,255,.06)}
.tlh-dot.is-open{background:#5ad17a;box-shadow:0 0 0 4px rgba(90,209,122,.18)}
.tlh-scroll-hint{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);color:var(--cream);opacity:.6;font-size:22px;animation:tlhbob 2s var(--ease) infinite}
@keyframes tlhbob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* =========================================================================
   Social proof strip
   ========================================================================= */
.tlh-proof{background:var(--accent);color:#fff;padding:0}
.tlh-proof-track{display:flex;flex-wrap:wrap;max-width:var(--maxw);margin:0 auto}
.tlh-proof-item{flex:1 1 50%;display:flex;flex-direction:column;align-items:center;gap:4px;padding:26px 16px;border-right:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18)}
.tlh-proof-stat{font-family:var(--serif);font-weight:800;font-size:clamp(24px,4vw,34px);line-height:1}
.tlh-proof-label{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;opacity:.92}

/* =========================================================================
   Cards grid base : 1 / 2 / 3
   ========================================================================= */
.tlh-cards{display:grid;grid-template-columns:1fr;gap:22px}

/* Menu featured cards */
.tlh-menu-feat{background:var(--bg)}
.tlh-menu-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
.tlh-menu-card:hover{transform:translateY(-6px);border-color:rgba(240,165,46,.45);box-shadow:0 24px 50px -28px rgba(0,0,0,.9)}
.tlh-menu-card-img{aspect-ratio:16/10;background-size:cover;background-position:center;transition:transform .5s var(--ease)}
.tlh-menu-card:hover .tlh-menu-card-img{transform:scale(1.06)}
.tlh-menu-card-body{padding:22px 24px 26px}
.tlh-menu-card-top{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.tlh-menu-card-top h3{font-size:21px;margin:0}
.tlh-price{font-family:var(--sans);font-weight:700;color:var(--accent-2);white-space:nowrap;font-size:16px}
.tlh-menu-card-body p{color:var(--muted);font-size:15px;margin:.5em 0 0}
.tlh-menu-cats{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:40px 0 26px}
.tlh-chip{border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-size:13.5px;font-weight:500;color:var(--cream);transition:all .3s var(--ease)}
.tlh-chip:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* =========================================================================
   Full menu list
   ========================================================================= */
.tlh-menu-full{max-width:980px}
.tlh-menu-group{margin-bottom:clamp(40px,6vw,64px);scroll-margin-top:90px}
.tlh-menu-cat-title{font-size:clamp(24px,4vw,34px);color:var(--accent-2);border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:24px}
.tlh-menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:22px}
.tlh-menu-row-main{display:flex;align-items:baseline;gap:10px}
.tlh-menu-name{font-family:var(--serif);font-weight:700;font-size:19px;color:var(--cream)}
.tlh-menu-dots{flex:1;border-bottom:1px dotted rgba(255,255,255,.22);transform:translateY(-4px)}
.tlh-menu-price{font-weight:700;color:var(--accent-2);white-space:nowrap}
.tlh-menu-desc{color:var(--muted);font-size:15px;margin:6px 0 0;max-width:70ch}

/* =========================================================================
   Story
   ========================================================================= */
.tlh-story{background:var(--bg-2);max-width:none}
.tlh-story-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(30px,5vw,64px);align-items:center}
.tlh-story-media{position:relative}
.tlh-story-media img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r)}
.tlh-story-badge{position:absolute;right:-6px;bottom:-18px;background:var(--accent);color:#fff;border-radius:var(--r);padding:16px 22px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;box-shadow:0 18px 40px -16px rgba(0,0,0,.8);text-align:center;line-height:1.3}
.tlh-story-badge span{display:block;font-family:var(--serif);font-size:30px;letter-spacing:0;text-transform:none}
.tlh-story-text p{color:var(--muted)}
.tlh-story-text .tlh-sec-title{font-size:clamp(28px,4.6vw,46px)}

/* =========================================================================
   Experience / steps + USPs
   ========================================================================= */
.tlh-exp{background:var(--bg)}
.tlh-steps{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:clamp(40px,6vw,70px);counter-reset:s}
.tlh-step{position:relative;padding:30px 26px;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.tlh-step-num{font-family:var(--serif);font-size:46px;font-weight:900;color:transparent;-webkit-text-stroke:1.5px var(--accent);display:block;line-height:1;margin-bottom:10px}
.tlh-step h3{font-size:22px}
.tlh-step p{color:var(--muted);margin:0}
.tlh-usps{display:grid;grid-template-columns:1fr;gap:20px;border-top:1px solid var(--line);padding-top:clamp(34px,5vw,54px)}
.tlh-usp{display:flex;gap:18px;align-items:flex-start}
.tlh-usp-num{font-family:var(--serif);font-weight:800;font-size:18px;color:var(--accent-2);border:1px solid rgba(240,165,46,.4);border-radius:50%;width:46px;height:46px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.tlh-usp h3{font-size:19px;margin:.1em 0 .3em}
.tlh-usp p{color:var(--muted);margin:0;font-size:15px}

/* =========================================================================
   Testimonials
   ========================================================================= */
.tlh-testi{background:var(--bg-2);max-width:none}
.tlh-testi .tlh-sec-head,.tlh-testi .tlh-cards{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.tlh-testi-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;margin:0;transition:transform .3s var(--ease),border-color .3s var(--ease)}
.tlh-testi-card:hover{transform:translateY(-5px);border-color:rgba(240,165,46,.4)}
.tlh-testi-stars{color:var(--accent-2);letter-spacing:3px;margin-bottom:12px}
.tlh-testi-card blockquote{margin:0 0 18px;font-size:16.5px;color:var(--text);line-height:1.65}
.tlh-testi-name{display:block;font-family:var(--serif);font-weight:700;color:var(--cream)}
.tlh-testi-meta{font-size:13px;color:var(--muted)}

/* =========================================================================
   Gallery masonry
   ========================================================================= */
.tlh-masonry{columns:2;column-gap:16px}
.tlh-masonry-item{margin:0 0 16px;border-radius:var(--r);overflow:hidden;break-inside:avoid;position:relative}
.tlh-masonry-item img{width:100%;display:block;transition:transform .6s var(--ease),filter .4s var(--ease);filter:saturate(1.02)}
.tlh-masonry-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(232,69,30,.25));opacity:0;transition:opacity .35s var(--ease)}
.tlh-masonry-item:hover img{transform:scale(1.07)}
.tlh-masonry-item:hover::after{opacity:1}
.tlh-masonry-item.m0,.tlh-masonry-item.m3{aspect-ratio:auto}

/* =========================================================================
   FAQ accordion
   ========================================================================= */
.tlh-faq{max-width:860px}
.tlh-accordion{border-top:1px solid var(--line)}
.tlh-acc-item{border-bottom:1px solid var(--line)}
.tlh-acc-q{width:100%;background:none;border:0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;text-align:left;padding:22px 4px;font-family:var(--serif);font-weight:700;font-size:clamp(17px,2.5vw,21px);color:var(--cream);transition:color .3s var(--ease)}
.tlh-acc-q:hover{color:var(--accent-2)}
.tlh-acc-ic{position:relative;width:18px;height:18px;flex:0 0 auto}
.tlh-acc-ic::before,.tlh-acc-ic::after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:transform .3s var(--ease)}
.tlh-acc-ic::before{top:8px;left:0;width:18px;height:2px}
.tlh-acc-ic::after{top:0;left:8px;width:2px;height:18px}
.tlh-acc-q[aria-expanded="true"] .tlh-acc-ic::after{transform:scaleY(0)}
.tlh-acc-a{overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.tlh-acc-a p{color:var(--muted);padding:0 4px 22px;margin:0;max-width:72ch}

/* =========================================================================
   Location
   ========================================================================= */
.tlh-location{max-width:none;background:var(--bg)}
.tlh-loc-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(28px,5vw,54px);align-items:stretch}
.tlh-loc-addr{font-family:var(--serif);font-size:22px;color:var(--cream);margin:0 0 4px}
.tlh-loc-hood{color:var(--accent-2);font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 24px}
.tlh-loc-hours,.tlh-foot-hours{list-style:none;margin:0 0 26px;padding:0}
.tlh-loc-hours li,.tlh-foot-hours li{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--line);font-size:15px}
.tlh-loc-hours li span:first-child{color:var(--cream);font-weight:600}
.tlh-loc-hours li span:last-child{color:var(--muted)}
.tlh-loc-cta{display:flex;flex-wrap:wrap;gap:12px}
.tlh-loc-map{min-height:340px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.tlh-loc-map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:grayscale(.3) contrast(1.05)}
.tlh-img-fallback{width:100%;height:100%;min-height:340px;background:linear-gradient(135deg,#1a120e,#2a1a12 60%,#0c0a09);border-radius:var(--r)}

/* =========================================================================
   Final CTA
   ========================================================================= */
.tlh-finalcta{background-size:cover;background-position:center;padding:clamp(70px,12vw,140px) var(--gutter);text-align:center}
.tlh-finalcta-inner{max-width:760px;margin:0 auto}
.tlh-finalcta-title{font-size:clamp(32px,6vw,60px);font-weight:900}
.tlh-finalcta-sub{color:var(--cream);opacity:.9;font-size:clamp(16px,2.4vw,20px);margin-bottom:30px}
.tlh-finalcta .tlh-hero-cta{justify-content:center}

/* =========================================================================
   Page hero + prose
   ========================================================================= */
.tlh-pagehero{background-size:cover;background-position:center;padding:140px var(--gutter) clamp(50px,8vw,80px)}
.tlh-pagehero-inner{max-width:var(--maxw);margin:0 auto}
.tlh-pagehero-title{font-size:clamp(34px,7vw,64px);font-weight:900;margin:0}
.tlh-pagehero-sub{color:var(--cream);opacity:.9;font-size:clamp(16px,2.3vw,20px);max-width:56ch;margin:.5em 0 0}
.tlh-crumbs{display:flex;gap:10px;font-size:13px;color:var(--muted);margin-bottom:16px}
.tlh-crumbs a:hover{color:var(--accent-2)}
.tlh-prose{max-width:780px;margin:0 auto}
.tlh-prose h2{font-size:clamp(26px,4vw,38px);margin-top:1.4em}
.tlh-prose h3{font-size:22px;margin-top:1.2em}
.tlh-prose a{color:var(--accent-2);border-bottom:1px solid rgba(240,165,46,.4)}
.tlh-prose img,.tlh-page-thumb img{border-radius:var(--r)}
.tlh-prose ul,.tlh-prose ol{padding-left:1.3em;color:var(--text)}
.tlh-prose li{margin:.4em 0}

/* =========================================================================
   Contact
   ========================================================================= */
.tlh-contact-grid{display:grid;grid-template-columns:1fr;gap:clamp(30px,5vw,56px)}
.tlh-form{display:flex;flex-direction:column;gap:16px}
.tlh-field{display:flex;flex-direction:column;gap:7px}
.tlh-field label{font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.tlh-field input,.tlh-field textarea{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:14px 16px;color:var(--cream);font-family:var(--sans);font-size:16px;transition:border-color .3s var(--ease)}
.tlh-field input:focus,.tlh-field textarea:focus{outline:none;border-color:var(--accent)}
.tlh-hp{position:absolute;left:-9999px}
.tlh-contact-info h3{font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);margin:22px 0 4px}
.tlh-contact-info h3:first-child{margin-top:0}
.tlh-notice{padding:14px 18px;border-radius:10px;font-weight:500}
.tlh-notice-ok{background:rgba(90,209,122,.12);border:1px solid rgba(90,209,122,.4);color:#9be3ad}
.tlh-notice-err{background:rgba(232,69,30,.12);border:1px solid rgba(232,69,30,.4);color:#f0a58e}

/* Posts */
.tlh-post-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.tlh-post-card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.tlh-post-card h3{padding:0 20px;margin:18px 0 8px;font-size:20px}
.tlh-post-card p{padding:0 20px 20px;color:var(--muted);font-size:14px}
.tlh-pagination{margin-top:40px;text-align:center}
.tlh-pagination a,.tlh-pagination .current{padding:10px 16px;border:1px solid var(--line);border-radius:8px;margin:0 4px}

/* =========================================================================
   Footer
   ========================================================================= */
.tlh-footer{background:#080605;border-top:1px solid var(--line);padding:clamp(50px,8vw,80px) var(--gutter) 30px}
.tlh-footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:36px}
.tlh-foot-brand img{width:72px;height:72px;border-radius:50%;margin-bottom:14px}
.tlh-foot-tag{font-family:var(--serif);font-size:18px;color:var(--cream);max-width:30ch}
.tlh-foot-social{display:flex;gap:16px;margin-top:14px}
.tlh-foot-social a{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.tlh-foot-social a:hover{color:var(--accent-2)}
.tlh-foot-col h4{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin:0 0 16px}
.tlh-foot-col p{margin:0 0 8px;color:var(--muted);font-size:15px}
.tlh-foot-col a:hover{color:var(--cream)}
.tlh-foot-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.tlh-foot-menu a{color:var(--muted);font-size:15px}
.tlh-foot-menu a:hover{color:var(--cream)}
.tlh-footer-bottom{max-width:var(--maxw);margin:40px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:12px;font-size:13px;color:var(--muted)}
.tlh-foot-legal{display:flex;gap:18px}
.tlh-foot-legal a:hover{color:var(--cream)}

/* =========================================================================
   Fixed mobile action bar
   ========================================================================= */
.tlh-actionbar{position:fixed;left:0;right:0;bottom:0;z-index:88;height:60px;display:flex;background:var(--accent);box-shadow:0 -6px 24px -10px rgba(0,0,0,.8);padding-bottom:env(safe-area-inset-bottom)}
.tlh-ab-item{flex:1 1 33.33%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#fff;border-right:1px solid rgba(255,255,255,.22);min-height:60px}
.tlh-ab-item:last-child{border-right:0}
.tlh-ab-ic{font-size:22px;line-height:1}
.tlh-ab-lbl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.tlh-ab-cta{background:rgba(0,0,0,.22)}

/* =========================================================================
   Responsive — tablet & desktop
   ========================================================================= */
@media (min-width:640px){
	.tlh-cards-3{grid-template-columns:repeat(2,1fr)}
	.tlh-steps{grid-template-columns:repeat(3,1fr)}
	.tlh-usps{grid-template-columns:repeat(3,1fr)}
	.tlh-proof-item{flex:1 1 25%}
	.tlh-masonry{columns:3}
	.tlh-contact-grid{grid-template-columns:1.3fr .9fr}
	.tlh-footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}
}
@media (min-width:1024px){
	.tlh-burger{display:none}
	.tlh-nav-desktop{display:flex}
	.tlh-actionbar{display:none}
	body.tlh-has-actionbar{padding-bottom:0}
	.tlh-cards-3{grid-template-columns:repeat(3,1fr)}
	.tlh-story-grid{grid-template-columns:1fr 1.05fr}
	.tlh-loc-grid{grid-template-columns:1fr 1.1fr}
	.tlh-footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr}
	.tlh-masonry{columns:3}
}
@media (min-width:1280px){
	.tlh-masonry{columns:3}
}

/* Scroll reveal */
.tlh-section,.tlh-finalcta,.tlh-proof{opacity:1}
@media (prefers-reduced-motion:no-preference){
	.tlh-reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
	.tlh-reveal.in{opacity:1;transform:none}
}
@media (prefers-reduced-motion:reduce){
	*{animation:none!important;scroll-behavior:auto!important}
}

/* =========================================================================
   Mobile UI refinements (phones) — overrides the mobile-first base above.
   ========================================================================= */
@media (max-width:480px){
	/* 3. Hero content padding — 20px from the edges (zero hero gutter so it nets 20px) */
	.tlh-hero{padding-left:0;padding-right:0}
	.tlh-hero-inner{padding:0 20px}
	/* 1. Hero H1 — keep under the size caps, never let it overflow/clip */
	.tlh-hero-title{font-size:40px;line-height:1.08;max-width:100%;padding-right:16px;
		word-wrap:break-word;overflow-wrap:break-word;hyphens:none}
	/* 2. Eyebrow — smaller + tighter so it stops wrapping badly */
	.tlh-kicker{font-size:11px;letter-spacing:.12em}
	/* 4. CTA buttons — a touch shorter, keep the pill */
	.tlh-btn-lg{padding:16px 24px;font-size:16px;border-radius:50px}
	.tlh-btn{border-radius:50px}
	.tlh-hero-cta{gap:12px}
	.tlh-hero-cta .tlh-btn{flex:1 1 auto}
}
@media (max-width:390px){
	.tlh-hero-title{font-size:38px}      /* cap 44px → comfortably under */
}
@media (max-width:375px){
	.tlh-hero-title{font-size:36px}      /* cap 42px → comfortably under */
	.tlh-kicker{font-size:10px;letter-spacing:.1em}
}
