
:root{
  --bg:#FCFAF8; --ink:#1A1410; --muted:#5F564F; --accent:#CC360C;
  --accent-dark:#A52A09; --accent-soft:#FBE9E2; --card:#FFFFFF;
  --line:#EBE3DC; --dark:#1A1410; --radius:18px; --maxw:1160px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;line-height:1.15;font-weight:700}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:76px 0}
.section-head{text-align:center;max-width:700px;margin:0 auto 48px}
.section-head h2{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:12px}
.section-head p{color:var(--muted)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 18px;z-index:999}
.skip-link:focus{left:12px}
.btn{display:inline-block;padding:13px 28px;border-radius:999px;font-weight:600;font-size:.95rem;transition:transform .25s,background .25s,color .25s,box-shadow .25s;cursor:pointer;border:0}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 22px rgba(204,54,12,.28)}
.btn-primary:hover{background:var(--accent-dark)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--accent)}
.btn-ghost{border:2px solid var(--ink);background:transparent}
.btn-ghost:hover{background:var(--ink);color:#fff}
/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(252,250,248,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(26,20,16,.08)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:76px;gap:16px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:46px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:'Poppins';font-weight:700;font-size:1.25rem;letter-spacing:-.5px}
.brand-name em{font-style:normal;color:var(--accent)}
.brand-sub{font-size:.58rem;letter-spacing:.42em;color:var(--muted);font-weight:600;margin-top:3px}
.nav-links{display:flex;gap:24px;list-style:none;font-weight:500;font-size:.95rem}
.nav-links a{position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:width .25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:14px}
.soc{display:flex;gap:8px}
.soc a{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);transition:.25s}
.soc a:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.soc svg{width:17px;height:17px}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;cursor:pointer}
@media(max-width:1024px){
  .nav-links{display:none;position:absolute;top:76px;left:0;right:0;background:var(--bg);flex-direction:column;padding:20px 24px;border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .nav-right .btn,.nav-right .soc{display:none}
}
/* ---------- hero ---------- */
.hero{padding:96px 0 72px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;text-align:center}}
.hero h1{font-size:clamp(2.3rem,5.4vw,4rem);margin-bottom:20px}
.hero h1 .hl{color:var(--accent);position:relative;white-space:nowrap}
.hero p{color:var(--muted);font-size:1.1rem;margin-bottom:30px;max-width:560px}
@media(max-width:860px){.hero p{margin:0 auto 30px}}
.hero-art{position:relative;display:flex;justify-content:center}
.hero-art img{width:min(380px,80%);animation:floaty 5s ease-in-out infinite}
.hero-art::before{content:"";position:absolute;inset:8%;background:radial-gradient(circle,var(--accent-soft),transparent 65%);z-index:-1;animation:pulse 5s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes pulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}
/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-art img,.hero-art::before,.marquee-track{animation:none!important}
  html{scroll-behavior:auto}
}
/* ---------- stats / partners ---------- */
.stats{display:flex;justify-content:center;gap:64px;flex-wrap:wrap;padding:42px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{text-align:center}
.stat b{font-family:'Poppins';font-size:2.5rem;display:block;color:var(--accent)}
.stat span{color:var(--muted)}
.marquee{overflow:hidden;position:relative;padding:8px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:64px;align-items:center;width:max-content;animation:marquee 26s linear infinite}
.marquee-track img{height:48px;width:auto;opacity:.9;object-fit:contain}
@keyframes marquee{to{transform:translateX(-50%)}}
/* ---------- cards ---------- */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.grid-3{grid-template-columns:repeat(2,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-3,.grid-2{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}}
/* ---------- team ---------- */
.team-card{text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:0 0 20px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .3s,box-shadow .3s,border-color .3s;overflow:hidden}
.team-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(26,20,16,.1);border-color:var(--accent)}
.team-card h3{font-size:1rem;margin:12px 0 0;padding:0 12px}
.team-role{color:var(--accent);font-size:.88rem;font-weight:600;margin:0;padding:0 8px}
.team-title{color:var(--muted);font-size:.82rem;margin:0}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:14px;transition:transform .3s,box-shadow .3s,border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(26,20,16,.1);border-color:var(--accent)}
.card img.thumb{border-radius:12px;height:180px;object-fit:cover;width:100%}
.card h3{font-size:1.25rem}
.card h3 a:hover{color:var(--accent)}
.card p{color:var(--muted);font-size:.96rem;flex:1}
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tags span{background:var(--accent-soft);border:1px solid #f3cdbd;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:500;color:var(--accent-dark)}
.card .btn{align-self:flex-start}
/* ---------- portfolio slider ---------- */
.slider{position:relative}
.slider-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 18px;scrollbar-width:none}
.slider-track::-webkit-scrollbar{display:none}
.slide{flex:0 0 min(480px,88%);scroll-snap-align:start;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s}
.slide:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(26,20,16,.12)}
.slide img{height:220px;width:100%;object-fit:cover}
.slide-body{padding:24px}
.slide-body .num{color:var(--accent);font-family:'Poppins';font-weight:700;letter-spacing:2px;font-size:.85rem}
.slide-body h3{margin:6px 0 2px;font-size:1.3rem}
.slide-body .type{color:var(--accent);font-weight:600;font-size:.88rem;margin-bottom:10px}
.slide-body p{color:var(--muted);font-size:.94rem}
.slider-nav{display:flex;gap:10px;justify-content:center;margin-top:18px}
.slider-nav button{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:#fff;font-size:1.2rem;cursor:pointer;transition:.25s;color:var(--ink)}
.slider-nav button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
/* ---------- about / team ---------- */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
@media(max-width:820px){.about-grid{grid-template-columns:1fr}}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}
@media(max-width:760px){.team-grid{grid-template-columns:repeat(2,1fr)}}
.team-card{text-align:center}
.team-card img{border-radius:0;aspect-ratio:3/4;object-fit:contain;object-position:top;width:100%;background:var(--card);transition:transform .3s}
.team-card:hover img{transform:scale(1.03)}
.team-card h4{margin-top:10px;font-size:1rem}
/* ---------- faq ---------- */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--card);margin-bottom:14px;overflow:hidden;transition:border-color .25s}
.faq-item[open]{border-color:var(--accent)}
.faq-item summary{cursor:pointer;padding:18px 22px;font-weight:600;font-family:'Poppins';list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-item summary::after{content:"+";font-size:1.4rem;color:var(--accent);transition:transform .25s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .ans{padding:0 22px 20px;color:var(--muted)}
/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-info p{margin-bottom:10px}
.contact-info a{font-weight:600;color:var(--accent)}
.map-embed{border:0;width:100%;height:240px;border-radius:var(--radius)}
form .field{margin-bottom:16px}
form label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
form input,form select,form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;font:inherit;transition:border-color .25s,box-shadow .25s}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
form textarea{min-height:120px;resize:vertical}
/* ---------- locations ---------- */
.loc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media(max-width:920px){.loc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.loc-grid{grid-template-columns:repeat(2,1fr)}}
.loc-chip{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 12px;text-align:center;font-weight:600;font-family:'Poppins';font-size:.95rem;transition:.25s;display:flex;flex-direction:column;align-items:center;gap:6px}
.loc-chip img{height:30px;width:auto}
.loc-chip:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-4px)}
.loc-chip:hover small{color:#ffd9cb}
.loc-chip small{font-family:'Inter';font-weight:400;color:var(--muted);font-size:.76rem}
.also-serving{margin-top:34px;text-align:center}
.also-serving h3{font-size:1.05rem;margin-bottom:14px}
.place-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:920px;margin:0 auto}
.place-tags span{background:#fff;border:1px solid var(--line);padding:5px 14px;border-radius:999px;font-size:.82rem;color:var(--muted);transition:.25s}
.place-tags span:hover{border-color:var(--accent);color:var(--accent)}
/* ---------- seo block ---------- */
.seo-block{background:var(--dark);color:#EFEAE5;padding:72px 0}
.seo-block h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:18px;color:#fff}
.seo-block p{color:#CDC4BC;max-width:880px;margin-bottom:14px}
.seo-block a{color:#FF7B4F;font-weight:600}
/* ---------- quote / footer ---------- */
.quote{padding:80px 24px;text-align:center}
.quote blockquote{font-family:'Poppins';font-size:clamp(1.5rem,3.4vw,2.4rem);max-width:760px;margin:0 auto 14px}
.quote cite{color:var(--muted);font-style:normal}
.site-footer{background:var(--dark);color:#CDC4BC;padding:64px 0 28px;border-top:6px solid var(--accent)}
.footer-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px;margin-bottom:40px}
@media(max-width:980px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
.site-footer h4{color:#fff;margin-bottom:14px;font-size:1rem}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:9px;font-size:.92rem}
.site-footer a:hover{color:#FF7B4F}
.footer-soc{display:flex;gap:10px;margin-top:14px}
.footer-soc a{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#2A211B;color:#fff;transition:.25s}
.footer-soc a:hover{background:var(--accent);transform:translateY(-3px)}
.footer-soc svg{width:18px;height:18px}
.footer-map iframe{width:100%;height:170px;border:0;border-radius:12px}
.footer-bottom{border-top:1px solid #2A211B;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem}
.footer-bottom a{color:#FF7B4F}
/* ---------- inner pages ---------- */
.page-hero{padding:84px 0 58px;text-align:center;background:linear-gradient(180deg,var(--accent-soft),var(--bg));border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2.1rem,5vw,3.4rem);max-width:880px;margin:0 auto 16px}
.page-hero p{max-width:700px;margin:0 auto;color:var(--muted);font-size:1.05rem}
.breadcrumbs{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.breadcrumbs a{color:var(--accent);font-weight:600}
.prose{max-width:820px;margin:0 auto}
.prose h2{font-size:1.5rem;margin:36px 0 12px}
.prose h3{font-size:1.15rem;margin:24px 0 8px}
.prose p,.prose li{color:var(--muted)}
.prose ul{padding-left:22px;margin:10px 0}
.prose p{margin-bottom:12px}
.check li{list-style:none;padding-left:30px;position:relative;margin-bottom:10px}
.check li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--accent);font-weight:700}
.cta-band{background:var(--accent);text-align:center;padding:56px 24px;color:#fff}
.cta-band h2{font-size:clamp(1.7rem,3.5vw,2.5rem);margin-bottom:18px;color:#fff}
.cta-band .btn{background:#fff;color:var(--accent)}
.cta-band .btn:hover{background:var(--ink);color:#fff}
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step}
@media(max-width:860px){.process{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.process{grid-template-columns:1fr}}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;position:relative;transition:transform .3s,box-shadow .3s}
.step:hover{transform:translateY(-5px);box-shadow:0 14px 32px rgba(26,20,16,.09)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:'Poppins';font-weight:700;color:var(--accent);font-size:1.5rem;display:block;margin-bottom:8px}
.step h3{font-size:1.05rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:.92rem}
#toTop{position:fixed;right:22px;bottom:22px;width:46px;height:46px;border-radius:50%;background:var(--accent);color:#fff;border:0;font-size:1.2rem;cursor:pointer;opacity:0;pointer-events:none;transition:.3s;z-index:70;box-shadow:0 10px 24px rgba(204,54,12,.35)}
#toTop.show{opacity:1;pointer-events:auto}
#toTop:hover{background:var(--accent-dark);transform:translateY(-3px)}
