/* Reset & base */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html:focus-within{scroll-behavior:smooth}
body{min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;background:#0f1115;color:#e9ecf1;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
img,svg,video{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}

/* Tokens */
:root{
  --bg:#0f1115;
  --panel:#131821;
  --ink:#e9ecf1;
  --muted:#9aa4b2;
  --line:#202736;
  --accent:#E4C27A;
  --radius:18px;
  --shadow:0 10px 36px rgba(0,0,0,.35);
  --display:"Playfair Display", Georgia, serif;
}

/* Containers & type */
.container{max-width:1200px;margin-inline:auto;padding:clamp(14px,3.3vw,28px)}
.section{font-family:var(--display);font-size:clamp(1.4rem,4.6vw,2.3rem);margin-bottom:.6rem}
.lead{font-size:clamp(1rem,2.8vw,1.1rem)}
.muted{color:var(--muted)}

/* Header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(15,17,21,.65);border-bottom:1px solid var(--line);backdrop-filter:saturate(1.1) blur(8px)}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:.8rem}
.brand{display:flex;align-items:center;gap:.65rem}
.logo{display:grid;place-items:center;width:85px;height:85px;border-radius:10px;background:linear-gradient(140deg,var(--accent),#00000);color:#00000;font-weight:800}
.brand-text{display:flex;flex-direction:column}
.brand-text em{font-style:normal;font-size:.82rem;color:var(--muted)}
.main-nav{display:flex;gap:.9rem;align-items:center;flex-wrap:wrap}
.main-nav a{color:#e9ecf1;opacity:.92}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.64rem .9rem;border:1px solid var(--line);border-radius:12px;background:#0c121c;box-shadow:var(--shadow);font-weight:600;color:#e9ecf1;cursor:pointer}
.btn.ghost{background:transparent;box-shadow:none}
.btn.accent{background:var(--accent);border-color:transparent;color:#0f1115}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:10px;padding:.55rem .7rem;color:#e9ecf1}

/* Social icons */
.social-icons{display:inline-flex;gap:.4rem;margin-left:.2rem}
.icon{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:#111723;color:#e9ecf1;transition:transform .12s ease}
.icon:active{transform:scale(.98)}

@media (max-width:1000px){.main-nav a{display:none}.main-nav .btn{display:none}.nav-toggle{display:inline-flex}}

/* Drawer */
.drawer{position:fixed;inset:64px 0 0 auto;background:#0c121c;border-left:1px solid var(--line);width:min(360px,92vw);padding:16px;display:flex;flex-direction:column;gap:.6rem;transform:translateX(100%);transition:transform .28s ease;z-index:80}
.drawer[aria-hidden="false"]{transform:translateX(0)}
.drawer a{padding:.9rem 1rem;border-radius:10px;border:1px solid var(--line);background:#111723}
.drawer .drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}
body.drawer-open{overflow:hidden}

/* Hero */
.hero{position:relative;isolation:isolate}
.hero img{width:100%;height:clamp(320px,58vh,620px);object-fit:cover;filter:brightness(.64)}
.hero .overlay{position:absolute;inset:0;display:grid;align-items:end;padding-bottom:clamp(10px,6vw,0px)}
.display{font-family:var(--display);font-size:clamp(1.9rem,9vw,4rem);line-height:1.12;margin:.35rem 0 .55rem}
.cta{display:flex;gap:.6rem;margin-top:.8rem;flex-wrap:wrap}

/* Sticky CTA */
.sticky-cta{position:fixed;left:16px;right:16px;bottom:16px;display:none}
@media (max-width:860px){.sticky-cta{display:block}}

/* Responsive grids/cards */
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(14px,3.2vw,26px)}
@media (max-width:900px){.two-col{grid-template-columns:1fr}}
.about-card{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px}
.stat{display:flex;flex-direction:column;gap:2px}
.stat strong{font-family:var(--display);font-size:clamp(1.2rem,4.2vw,1.6rem)}
.ticks{margin:10px 0 0 0;display:grid;gap:.35rem}
.ticks li{list-style:none}
.ticks li::before{content:"✔︎";margin-right:.5rem;color:var(--accent)}
.mini-cta{display:flex;gap:.5rem;margin-top:10px}

/* Services */
.services{padding:clamp(32px,7vw,84px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,2vw,20px);margin-top:10px}
@media (max-width:900px){.cards{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:clamp(14px,2vw,18px)}
.card .badge{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(140deg,var(--accent),#cfb36e);font-weight:800;color:#1a1d24;margin-bottom:.5rem}

/* Media */
.media{padding:clamp(32px,7vw,84px) 0;border-bottom:1px solid var(--line)}
.media-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(14px,3.2vw,26px)}
@media (max-width:900px){.media-grid{grid-template-columns:1fr}}
.ratio{position:relative;padding-top:56.25%}
.ratio>iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gallery img{aspect-ratio:1/1;border-radius:12px;border:1px solid var(--line);background:#0c121c;object-fit:cover}

/* Testimonials */
.testimonials{padding:clamp(32px,7vw,84px) 0;border-bottom:1px solid var(--line)}
.quote-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,2vw,20px)}
@media (max-width:900px){.quote-cards{grid-template-columns:1fr}}
.q{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:clamp(14px,2vw,18px)}
.q blockquote{font-size:1.02rem}
.q figcaption{margin-top:.45rem;color:#9aa4b2}

/* FAQ */
.faq{padding:clamp(32px,7vw,84px) 0;border-bottom:1px solid var(--line)}
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,2vw,20px)}
@media (max-width:900px){.faq-grid{grid-template-columns:1fr}}
details{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
summary{cursor:pointer;font-weight:600}

/* Contact */
.contact{padding:clamp(32px,7vw,84px) 0;border-bottom:1px solid var(--line)}
.form{display:grid;gap:.9rem}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem}
@media (max-width:900px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-size:.92rem;color:#9aa4b2}
.field input,.field textarea{background:#0c121c;border:1px solid var(--line);border-radius:12px;padding:.85rem;color:#e9ecf1}
.field textarea{min-height:140px}
.col-2{grid-column:1 / -1}
/* focus & invalid states */
.field input:focus,.field textarea:focus{outline:2px solid var(--accent);outline-offset:2px;border-color:var(--accent)}
.field input:invalid[aria-invalid="true"],.field textarea:invalid[aria-invalid="true"]{border-color:#e24a4a;box-shadow:0 0 0 3px rgba(226,74,74,.15)}
.info{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px}
.info hr{border:0;border-top:1px solid var(--line);margin:10px 0}

/* Footer */
.site-footer{padding:24px 0;color:#9aa4b2}


/* EmailJS status + thank-you */
.form-status{font-size:.95rem}
.form-status.ok{color:#9bd67b}
.form-status.err{color:#ff8b8b}
.form-thanks{background:var(--panel,#131821);border:1px solid var(--line,#202736);border-radius:16px;padding:16px;margin-top:10px}
.form-thanks h3{margin:0 0 .4rem 0}
