/* ============================================================
   PORSSE — Luxury Redefined. Shared design system.
   Black + gold editorial luxury · Cormorant + Montserrat.
   Used by every page. Keep all components here.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant:wght@400;500;600;700&family=Montserrat:wght@300;400;500;600;700&display=swap');

:root{
  --black:#0b0a08; --ink:#171410; --ink-2:#26221b;
  --paper:#fbf9f4; --cream:#f4efe6; --card:#ffffff;
  --gold:#c2a25e; --gold-deep:#9c7c3a; --gold-bright:#e7cf94;
  --gold-grad:linear-gradient(96deg,#9c7c3a 0%,#e7cf94 42%,#fbf3cf 52%,#c2a25e 62%,#9c7c3a 100%);
  --txt:#1a1611; --muted:#7c7466; --muted-2:#9a9182;
  --line:#e7e0d3; --line-gold:rgba(194,162,94,.30);
  --on-dark:#f3efe6; --on-dark-mut:#b6ad9c;
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',sans-serif;background:var(--paper);color:var(--txt);
  font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--gold);color:#1a1206}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(24px,5vw,56px)}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:'Cormorant',serif;font-weight:600;line-height:1.04;letter-spacing:-.01em;color:var(--ink)}
.display{font-size:clamp(44px,8vw,104px);font-weight:600;line-height:.98}
h2.sec{font-size:clamp(30px,4.4vw,56px)}
.eyebrow{font-family:'Montserrat';font-weight:600;font-size:11px;letter-spacing:.30em;text-transform:uppercase;color:var(--gold-deep)}
.lede{font-size:clamp(15px,1.5vw,18px);color:var(--muted);max-width:56ch;line-height:1.8}
.gold-text{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.serif-it{font-family:'Cormorant';font-style:italic;font-weight:500}

/* gold hairline + ornament */
.rule{height:1px;background:linear-gradient(90deg,transparent,var(--gold-line,var(--line-gold)),transparent);border:0}
.orn{display:inline-flex;align-items:center;gap:14px;color:var(--gold-deep)}
.orn::before,.orn::after{content:"";width:46px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.orn .d{width:5px;height:5px;background:var(--gold);transform:rotate(45deg)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:0;
  font-family:'Montserrat';font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:16px 32px;background:var(--gold);color:#171206;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 34px -14px rgba(156,124,58,.7)}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn.outline{background:transparent;color:var(--ink);border:1px solid var(--gold)}
.btn.outline:hover{background:var(--gold);color:#171206;box-shadow:none}
.btn.on-dark{border-color:var(--gold);color:var(--on-dark)}
.btn.on-dark:hover{background:var(--gold);color:#171206}
.btn.dark{background:var(--ink);color:var(--on-dark)}
.btn.dark:hover{background:#000}
.btn.sm{padding:12px 22px;font-size:11px}
.btn.block{width:100%;justify-content:center}

/* ---------- nav ---------- */
.nav{position:fixed;inset:0 0 auto;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,56px);transition:background .4s var(--ease),padding .4s,box-shadow .4s;color:var(--on-dark)}
.nav.scrolled{background:rgba(251,249,244,.92);backdrop-filter:saturate(140%) blur(14px);color:var(--ink);
  box-shadow:0 1px 0 var(--line);padding-top:13px;padding-bottom:13px}
.nav .brand{display:flex;align-items:center;gap:12px;font-family:'Cormorant';font-weight:600;font-size:25px;letter-spacing:.18em}
.nav .brand img{height:38px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.nav .brand .tag{font-family:'Montserrat';font-size:8px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);display:block;margin-top:-3px}
.nav .links{display:flex;align-items:center;gap:30px}
.nav .links a{font-family:'Montserrat';font-weight:500;font-size:12px;letter-spacing:.13em;text-transform:uppercase;opacity:.92;position:relative;padding:4px 0}
.nav .links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--gold);transition:width .3s var(--ease)}
.nav .links a:hover::after{width:100%}
.nav .ico{display:flex;align-items:center;gap:18px}
.nav .ico svg{width:20px;height:20px;cursor:pointer;stroke:currentColor;fill:none;stroke-width:1.6}
.nav .cartbtn{position:relative}
.nav .cartbtn .cnt{position:absolute;top:-7px;right:-9px;background:var(--gold);color:#171206;font-family:'Montserrat';font-weight:700;font-size:9px;border-radius:999px;min-width:15px;height:15px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.burger span{width:24px;height:1.5px;background:currentColor;display:block}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;background:var(--black);color:var(--on-dark);transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:26px clamp(20px,7vw,40px)}
.drawer.open{transform:none}
.drawer .x{align-self:flex-end;background:none;border:0;color:var(--on-dark);font-size:30px;cursor:pointer;line-height:1;width:46px;height:46px;display:flex;align-items:center;justify-content:center;margin:-6px -10px 4px 0}
.drawer a{font-family:'Cormorant';font-size:34px;font-weight:500;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.drawer a:hover{color:var(--gold)}

/* ---------- announcement bar ---------- */
.annc{background:var(--black);color:var(--gold-bright);text-align:center;font-family:'Montserrat';font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;padding:9px 16px;position:relative;z-index:61}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--black);color:var(--on-dark);overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover;opacity:.62}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,10,8,.55) 0%,transparent 30%,transparent 45%,rgba(11,10,8,.86) 100%)}
.hero .inner{position:relative;z-index:1;width:100%;padding-block:90px 40px}
.hero .display{color:var(--on-dark);max-width:16ch}
.hero .display em{font-style:italic;color:var(--gold-bright)}
.hero .sub{color:var(--on-dark-mut);max-width:48ch;margin:22px 0 32px;font-size:clamp(15px,1.5vw,18px);line-height:1.8}
.ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:1;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint .ln{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);animation:drop 2s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(.3);transform-origin:top;opacity:.3}50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(.3);transform-origin:bottom;opacity:.3}}

/* ---------- sections ---------- */
.section{padding:clamp(64px,10vw,132px) 0}
.section.dark{background:var(--black);color:var(--on-dark)}
.section.cream{background:var(--cream)}
.section.dark h1,.section.dark h2,.section.dark h3{color:var(--on-dark)}
.section.dark .lede{color:var(--on-dark-mut)}
.sec-head{text-align:center;max-width:60ch;margin:0 auto clamp(40px,6vw,64px)}
.sec-head .eyebrow{margin-bottom:16px;display:inline-block}
.sec-head .lede{margin:18px auto 0}

/* trust strip */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-gold);border-block:1px solid var(--line-gold)}
.section.dark .trust{background:rgba(194,162,94,.18);border-color:rgba(194,162,94,.18)}
.trust .t{background:var(--paper);padding:30px 22px;text-align:center}
.section.dark .trust .t{background:var(--black)}
.trust .t svg{width:30px;height:30px;stroke:var(--gold);fill:none;stroke-width:1.3;margin:0 auto 12px}
.trust .t b{font-family:'Cormorant';font-size:21px;font-weight:600;display:block}
.trust .t span{font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.section.dark .trust .t span{color:var(--on-dark-mut)}

/* ---------- category tiles ---------- */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--ink);color:var(--on-dark);display:flex;align-items:flex-end}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.72;transition:transform 1s var(--ease),opacity .5s}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,10,8,.82))}
.cat:hover img{transform:scale(1.06);opacity:.85}
.cat .c{position:relative;z-index:1;padding:30px}
.cat .c h3{color:var(--on-dark);font-size:30px}
.cat .c span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);display:inline-flex;align-items:center;gap:8px;margin-top:8px}

/* ---------- product card ---------- */
.grid-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:clamp(18px,2.4vw,34px)}
.pcard{background:var(--card);border:1px solid var(--line);transition:border-color .3s,box-shadow .3s,transform .3s var(--ease);display:flex;flex-direction:column;min-width:0}
.pcard:hover{border-color:var(--gold-line);box-shadow:0 26px 54px -30px rgba(60,46,18,.4);transform:translateY(-4px)}
.pcard .ph{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--cream)}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.pcard:hover .ph img{transform:scale(1.05)}
.pcard .tag{position:absolute;top:14px;left:14px;background:var(--black);color:var(--gold-bright);font-size:9.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:5px 11px}
.pcard .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:4px;flex:1}
.pcard .cat-l{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep)}
.pcard .body h3{font-size:24px;line-height:1.1}
.pcard .stars{color:var(--gold);font-size:12px;letter-spacing:2px}
.pcard .pr{margin-top:auto;display:flex;align-items:baseline;gap:10px;padding-top:12px}
.pcard .pr .now{font-family:'Cormorant';font-size:26px;font-weight:600}
.pcard .pr .was{color:var(--muted-2);text-decoration:line-through;font-size:14px}
.pcard .add{margin-top:14px}

/* feature split */
.split{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(30px,6vw,76px)}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.split .media{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--ink)}
.split .media img{width:100%;height:100%;object-fit:cover}
.split .media .bdg{position:absolute;bottom:0;left:0;background:var(--gold);color:#171206;padding:16px 22px;font-family:'Cormorant';font-weight:600;font-size:20px}

/* spec list */
.specs{list-style:none;display:grid;gap:0}
.specs li{display:flex;justify-content:space-between;gap:20px;padding:14px 0;border-bottom:1px solid var(--line)}
.specs li span:first-child{color:var(--muted);font-size:13px;letter-spacing:.04em;text-transform:uppercase}
.specs li span:last-child{font-family:'Cormorant';font-size:19px;font-weight:600}
.section.dark .specs li{border-color:rgba(255,255,255,.08)}

/* testimonial */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{padding:34px;border:1px solid var(--line-gold);background:var(--paper)}
.section.dark .quote{background:rgba(255,255,255,.02)}
.quote .q{font-family:'Cormorant';font-size:22px;font-weight:500;line-height:1.45;font-style:italic}
.quote .who{margin-top:18px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-deep)}
.quote .who b{display:block;font-family:'Cormorant';font-style:normal;font-size:17px;letter-spacing:0;text-transform:none;color:var(--ink)}
.section.dark .quote .who b{color:var(--on-dark)}

/* ---------- forms ---------- */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea,.field select{font-family:'Montserrat';font-size:14px;padding:13px 15px;border:1px solid var(--line);background:#fff;color:var(--txt);border-radius:0;transition:border-color .25s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold)}

/* ---------- footer ---------- */
.footer{background:var(--black);color:var(--on-dark-mut);padding:clamp(56px,8vw,90px) 0 32px}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer .brand{font-family:'Cormorant';font-size:30px;letter-spacing:.18em;color:var(--on-dark)}
.footer .brand .tag{font-family:'Montserrat';font-size:9px;letter-spacing:.34em;color:var(--gold);text-transform:uppercase;margin-top:2px}
.footer p{font-size:13.5px;line-height:1.8;margin-top:16px;max-width:34ch}
.footer h4{font-family:'Montserrat';font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer ul{list-style:none;display:grid;gap:11px}
.footer ul a{font-size:13.5px;opacity:.85;transition:color .2s}
.footer ul a:hover{color:var(--gold-bright)}
.footer .bottom{margin-top:clamp(40px,6vw,64px);padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:11.5px;letter-spacing:.04em}

/* ---------- whatsapp float ---------- */
.wa{position:fixed;right:22px;bottom:22px;z-index:70;display:inline-flex;align-items:center;gap:11px;background:#1faf54;color:#fff;
  padding:13px 19px 13px 15px;border-radius:999px;box-shadow:0 14px 30px -8px rgba(31,175,84,.6);font-weight:600;font-size:13px;
  transition:transform .25s var(--ease)}
.wa:hover{transform:translateY(-3px) scale(1.02)}
.wa svg{width:24px;height:24px;fill:#fff}
.wa .lbl{letter-spacing:.02em}
@media(max-width:560px){.wa .lbl{display:none}.wa{padding:14px;right:16px;bottom:16px}}

/* ---------- breadcrumb ---------- */
.crumb{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:104px 0 0}
.crumb a:hover{color:var(--gold-deep)}
.crumb .sep{margin:0 8px;color:var(--gold)}

/* page header (interior pages) */
.phead{background:var(--black);color:var(--on-dark);padding:140px clamp(24px,5vw,56px) 64px;text-align:center}
.phead .wrap{padding-inline:0}
.phead .eyebrow{color:var(--gold);margin-bottom:14px;display:inline-block}
.phead h1{color:var(--on-dark);font-size:clamp(38px,6vw,72px)}
.phead .lede{color:var(--on-dark-mut);margin:16px auto 0}

/* utility */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.center{text-align:center}
.mt-cta{margin-top:38px}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .footer .top{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:34px}.split.rev{direction:ltr}
  .quotes{grid-template-columns:1fr}
}
@media(max-width:760px){
  .nav .links,.nav .ico .desk{display:none}
  .burger{display:flex}
  .cats{grid-template-columns:1fr;gap:14px}
  .cat{aspect-ratio:16/10}
  .trust{grid-template-columns:1fr 1fr}
  .footer .top{grid-template-columns:1fr}
  .ctas{gap:12px}
  .btn{padding:15px 24px;font-size:11.5px}
  .chip{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  .hero{min-height:88vh}
  .hero .inner{padding-block:80px 24px}
  .hero .sub{font-size:15px;margin:18px 0 26px}
  .annc{font-size:9px;letter-spacing:.1em;padding:8px 12px}
  .phead{padding-block:116px 46px}
  .split .media{aspect-ratio:4/3}
  .quotes .row,.outro .row{flex-direction:column}
  .nav{padding:14px 20px}
}
@media(max-width:480px){
  .grid-products{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .pcard .body{padding:14px 14px 18px}
  .pcard .body h3{font-size:19px}
  .trust{grid-template-columns:1fr 1fr}
  .section{padding:54px 0}
  .wa .lbl{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important}}
