:root{
  --gold:#FFC252;
  --gold-deep:#F1A93C;
  --amber:#FFAB4A;
  --bronze:#C8862B;
  --ink:#2A2722;
  --ink-soft:#5b554c;
  --cream:#FBF6EC;
  --cream-2:#F6EEDD;
  --white:#ffffff;
  --line:rgba(42,39,34,.12);
  --shadow:0 18px 50px -22px rgba(80,55,10,.45);
  --radius:16px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Helvetica Neue",Helvetica,Arial,"Nimbus Sans","Liberation Sans",system-ui,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Raleway',"Helvetica Neue",Arial,sans-serif;line-height:1.12;font-weight:700;letter-spacing:-.01em}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.container--narrow{max-width:560px;margin:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:14px 28px;border-radius:999px;font-weight:600;font-size:.96rem;
  letter-spacing:.02em;cursor:pointer;border:1.6px solid transparent;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
}
.btn--solid{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--ink)}
.btn--solid:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(200,134,43,.6);filter:brightness(1.05)}
.btn--ghost{background:transparent;border-color:rgba(42,39,34,.4);color:var(--ink)}
.btn--ghost:hover{background:var(--gold);color:var(--ink);border-color:var(--gold);transform:translateY(-2px)}
.btn--onfill{border-color:rgba(255,255,255,.7);color:#fff}
.btn--onfill:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--block{width:100%}

/* ---------- Nav ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;transition:background .3s,box-shadow .3s,padding .3s}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.nav__logo{display:block;height:46px;transition:height .3s}
.nav__logo img{height:100%;width:auto;display:block;filter:drop-shadow(0 2px 6px rgba(40,25,0,.22))}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-size:.93rem;font-weight:600;color:#fff;letter-spacing:.02em;position:relative;opacity:.92;transition:opacity .2s}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:currentColor;transition:right .3s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:not(.nav__cta):hover::after{right:0}
.nav__cta{background:rgba(255,255,255,.16);border:1.5px solid rgba(255,255,255,.55);padding:9px 20px;border-radius:999px;backdrop-filter:blur(4px)}
.nav__cta:hover{background:#fff;color:var(--ink)!important}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__burger span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}

/* scrolled state — dark bar so the white logo stays visible */
.nav.scrolled{background:rgba(33,30,26,.92);box-shadow:0 6px 24px -16px rgba(0,0,0,.55);backdrop-filter:blur(9px)}
.nav.scrolled .nav__inner{padding-top:12px;padding-bottom:12px}
.nav.scrolled .nav__logo{height:40px}
.nav.scrolled .nav__cta{background:var(--gold);color:var(--ink)!important;border-color:var(--gold)}
.nav.scrolled .nav__cta:hover{background:#fff;border-color:#fff;color:var(--ink)!important}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;padding:120px 24px 90px;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,#FFD588,#F1A93C)}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__tint{position:absolute;inset:0;background:linear-gradient(155deg,rgba(255,201,96,.50),rgba(228,148,42,.72));mix-blend-mode:multiply}
.hero__veil{position:absolute;inset:0;background:radial-gradient(130% 105% at 50% 32%,rgba(35,22,0,0),rgba(35,22,0,.52)),linear-gradient(180deg,rgba(35,22,0,.34),rgba(35,22,0,.05) 28%,rgba(35,22,0,.30))}
.hero__grain{position:absolute;inset:0;opacity:.09;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero__fade{position:absolute;left:0;right:0;bottom:-1px;height:130px;background:linear-gradient(180deg,rgba(255,255,255,0),#fff);z-index:1}
.hero__content{position:relative;z-index:2;max-width:860px;animation:rise .9s var(--ease) both}
.hero__logo{display:block;margin:0 auto 28px;width:min(390px,76vw)}
.hero__logo img{width:100%;height:auto;filter:drop-shadow(0 10px 24px rgba(35,22,0,.5))}
.hero__eyebrow{text-transform:uppercase;letter-spacing:.32em;font-size:.74rem;font-weight:600;opacity:.9;margin-bottom:16px}
.hero__title{font-size:clamp(2.1rem,5.4vw,4rem);font-weight:800;text-shadow:0 4px 24px rgba(90,55,5,.25)}
.hero__sub{margin:22px auto 0;max-width:620px;font-size:clamp(1rem,1.4vw,1.18rem);font-weight:400;opacity:.96;text-shadow:0 2px 10px rgba(90,55,5,.2)}
.hero__actions{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .btn--solid{background:#fff;color:var(--ink)}
.hero .btn--solid:hover{background:var(--ink);color:#fff}
.hero .btn--ghost{border-color:rgba(255,255,255,.8);color:#fff}
.hero .btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:2px solid rgba(255,255,255,.7);border-radius:14px}
.hero__scroll span{position:absolute;left:50%;top:8px;width:4px;height:8px;background:#fff;border-radius:2px;transform:translateX(-50%);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* ---------- Sections ---------- */
.section{padding:clamp(64px,9vw,120px) 0}
.section--cream{background:var(--cream)}
.section--gold{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#fff}
.section__head{max-width:760px;margin-bottom:54px}
.section__head h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
.section__intro{margin-top:18px;color:var(--ink-soft);font-size:1.05rem}
.kicker{display:inline-block;text-transform:uppercase;letter-spacing:.26em;font-size:.74rem;font-weight:700;color:var(--bronze);margin-bottom:14px}
.kicker--light{color:rgba(255,255,255,.85)}

/* reveal on scroll — only when JS is active, so content is always visible otherwise */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* ---------- About ---------- */
.about__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:54px;align-items:start}
.about__lead p{margin-bottom:18px;color:var(--ink-soft);font-size:1.05rem}
.about__lead strong{color:var(--ink)}
.about__pillars{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.about__pillars h3{font-size:1.25rem}
.about__pillars-intro{color:var(--ink-soft);margin:10px 0 22px;font-size:.98rem}
.pillar{display:flex;gap:16px;margin-bottom:20px}
.pillar__icon{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(150deg,var(--gold),var(--amber));color:#fff}
.pillar__icon svg{width:22px;height:22px}
.pillar h4{font-size:1.02rem;margin-bottom:3px}
.pillar p{font-size:.92rem;color:var(--ink-soft);line-height:1.5}
.about__link{display:inline-block;margin-top:8px;font-weight:600;color:var(--bronze)}
.about__link:hover{text-decoration:underline}

/* ---------- Products cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--gold),var(--amber));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card__icon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(150deg,var(--gold),var(--gold-deep));color:#fff;margin-bottom:18px}
.card__icon svg{width:28px;height:28px}
.card h3{font-size:1.18rem;margin-bottom:14px}
.card ul{list-style:none}
.card li{position:relative;padding-left:20px;margin-bottom:9px;color:var(--ink-soft);font-size:.93rem;line-height:1.45}
.card li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:50%;background:var(--gold-deep)}

/* ---------- Located ---------- */
.located{padding:0}
.located__grid{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.located__panel{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#fff;display:flex;align-items:center;padding:clamp(48px,7vw,90px) 0}
.located__panel .container--narrow{padding:0 clamp(28px,5vw,70px)}
.located__panel h2{font-size:clamp(2rem,4vw,3.1rem);margin:6px 0 18px}
.located__panel p{opacity:.95;margin-bottom:22px}
.located__addr{font-style:normal;font-size:1.05rem;line-height:1.8;margin-bottom:26px;font-weight:500}
.located__map{position:relative}
.located__map svg{position:absolute;inset:0;width:100%;height:100%}

/* ---------- Contact ---------- */
.contact__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:54px;align-items:start}
.contact__intro h2{font-size:clamp(1.9rem,3.6vw,2.8rem)}
.contact__intro p{opacity:.95;margin:16px 0 28px;max-width:420px}
.contact__details{list-style:none;display:flex;flex-direction:column;gap:16px}
.contact__details li{display:flex;align-items:center;gap:14px;font-size:1.05rem;font-weight:500}
.contact__details a:hover{text-decoration:underline}
.contact__ic{flex:none;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.4)}
.contact__ic svg{width:20px;height:20px;color:#fff}
.contact__form{background:#fff;color:var(--ink);border-radius:var(--radius);padding:30px;box-shadow:0 30px 60px -30px rgba(60,35,0,.55)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:block;margin-bottom:16px}
.field span{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.02em}
.field input,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.96rem;color:var(--ink);background:var(--cream);transition:border-color .2s,background .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold-deep);background:#fff;box-shadow:0 0 0 3px rgba(255,194,82,.25)}
.field textarea{resize:vertical}
.form__status{margin-top:14px;font-size:.92rem;font-weight:600;min-height:1.2em}
.form__status.ok{color:#1c7a3d}
.form__status.err{color:#c0392b}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cfc8bc}
.footer__inner{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;padding-top:64px;padding-bottom:40px}
.footer__logo{display:block;width:220px;max-width:62%;margin-bottom:18px}
.footer__logo img{width:100%;height:auto}
.footer__brand p{max-width:360px;font-size:.95rem;line-height:1.6}
.footer__meta p{font-size:.95rem;line-height:1.7;margin-bottom:18px}
.footer__links{display:flex;flex-wrap:wrap;gap:8px 22px}
.footer__links a{font-size:.92rem;font-weight:600;color:#e9e2d6}
.footer__links a:hover{color:var(--gold)}
.footer__bar{border-top:1px solid rgba(255,255,255,.12)}
.footer__bar-inner{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;font-size:.86rem;color:#a79f91}
.footer__bar-inner a:hover{color:var(--gold)}

/* ---------- Cookie consent ---------- */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 22px 55px -22px rgba(60,35,0,.5);padding:18px 22px;transform:translateY(160%);transition:transform .5s var(--ease)}
.cookie.show{transform:none}
.cookie__inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.cookie__text{flex:1;min-width:240px;margin:0;font-size:.92rem;line-height:1.5;color:var(--ink-soft)}
.cookie__btns{display:flex;gap:10px}
.cookie .btn{padding:11px 24px;font-size:.9rem}
@media (max-width:560px){.cookie__btns{width:100%}.cookie__btns .btn{flex:1}}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .about__grid{grid-template-columns:1fr;gap:36px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .contact__grid{grid-template-columns:1fr;gap:36px}
  .located__grid{grid-template-columns:1fr}
  .located__map{min-height:280px;order:-1}
  .footer__inner{grid-template-columns:1fr;gap:28px}
}
@media (max-width:680px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:#fff;flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;padding:40px 34px;transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:-20px 0 50px -20px rgba(0,0,0,.4)}
  .nav__links.open{transform:none}
  .nav__links a{color:var(--ink)!important;font-size:1.05rem;padding:8px 0;width:100%}
  .nav__links a:not(.nav__cta)::after{display:none}
  .nav__cta{background:var(--ink);color:#fff!important;border-color:var(--ink);margin-top:8px}
  .nav__burger{display:flex;z-index:60}
  .nav__burger.active span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav__burger.active span:nth-child(2){opacity:0}
  .nav__burger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .nav__burger.active span{background:var(--ink)}
  .form__row{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .hero__actions{flex-direction:column}
  .hero__actions .btn{width:100%}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important;transition:none!important}
}
