/* Washmahal — global system */
:root{
  --bg: #06080c;
  --bg-1: #0a0d13;
  --bg-2: #0e1218;
  --bg-3: #161b24;
  --line: rgba(255,255,255,0.08);
  --line-strong: rgba(255,255,255,0.16);
  --text: #f3f5f7;
  --text-mute: #8a93a3;
  --text-dim: #5b6473;
  --accent: #00e0ff;        /* water cyan */
  --accent-dim: #0098ad;
  --gold: #d4a85a;          /* champagne — premium tier */
  --danger: #ff5c5c;
  --radius: 14px;
  --radius-lg: 22px;
  --maxw: 1440px;
  --pad: clamp(20px, 4vw, 56px);
  --display: "Anton", "Archivo Black", Impact, sans-serif;
  --body: "Manrope", system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
html,body{background:var(--bg);color:var(--text);font-family:var(--body);font-weight:400;font-size:16px;line-height:1.5;overflow-x:clip}
body{min-height:100vh}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;background:none;border:none;color:inherit;cursor:pointer}
::selection{background:var(--accent);color:#000}

/* Typography */
.display{font-family:var(--display);font-weight:400;letter-spacing:-0.01em;line-height:0.92;text-transform:uppercase}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-mute)}
.eyebrow .dot{display:inline-block;width:6px;height:6px;background:var(--accent);border-radius:50%;margin-right:10px;vertical-align:middle;box-shadow:0 0 12px var(--accent)}
.mono{font-family:var(--mono);letter-spacing:0.04em}

h1,h2,h3{font-family:var(--display);font-weight:400;letter-spacing:-0.01em;line-height:0.95;text-transform:uppercase}
h1{font-size:clamp(48px,9vw,148px)}
h2{font-size:clamp(36px,6vw,88px)}
h3{font-size:clamp(22px,2.4vw,32px)}
p{color:var(--text-mute);max-width:62ch}
p.lead{font-size:clamp(17px,1.4vw,20px);color:#c8ccd4;line-height:1.55}

/* Layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
section{position:relative}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-family:var(--mono);font-size:12px;letter-spacing:0.15em;text-transform:uppercase;
  border:1px solid var(--line-strong);transition:all .25s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--accent);color:#000;border-color:var(--accent)}
.btn-primary:hover{box-shadow:0 0 0 6px rgba(0,224,255,0.18);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.3)}
.btn-wa{background:#1faa54;color:#fff;border-color:#1faa54}
.btn-wa:hover{box-shadow:0 0 0 6px rgba(31,170,84,0.22)}
.btn .arrow{display:inline-block;transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* Nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  backdrop-filter:blur(18px);
  background:linear-gradient(to bottom, rgba(6,8,12,0.85), rgba(6,8,12,0.4));
  border-bottom:1px solid var(--line);
  transition:all .3s;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:22px;letter-spacing:0.04em;text-transform:uppercase}
.nav-logo-mark{
  width:34px;height:34px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--accent), #003e4a);
  position:relative;flex-shrink:0;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.2), 0 0 20px rgba(0,224,255,0.4);
}
.nav-logo-mark::after{
  content:"";position:absolute;top:6px;left:7px;
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,0.7);filter:blur(2px);
}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  padding:10px 14px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--text-mute);transition:all .2s;
}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,0.06)}
.nav-links a.active{color:var(--text);background:rgba(255,255,255,0.08)}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-burger{display:none;width:42px;height:42px;border-radius:50%;border:1px solid var(--line-strong);align-items:center;justify-content:center}
.nav-burger span{display:block;width:18px;height:1.5px;background:var(--text);position:relative}
.nav-burger span::before,.nav-burger span::after{content:"";position:absolute;left:0;width:100%;height:1.5px;background:var(--text)}
.nav-burger span::before{top:-5px}
.nav-burger span::after{top:5px}

@media (max-width:900px){
  .nav-links,.nav-cta .btn-ghost{display:none}
  .nav-burger{display:flex}
}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:99;
  background:var(--bg);
  padding:100px var(--pad) 40px;
  display:none;flex-direction:column;gap:20px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--display);font-size:42px;text-transform:uppercase;color:var(--text)}
.mobile-menu a:hover{color:var(--accent)}

/* Footer */
.footer{border-top:1px solid var(--line);background:var(--bg-1);padding:80px var(--pad) 32px;margin-top:120px}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr repeat(3, 1fr);gap:48px}
.footer h4{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-mute);margin-bottom:18px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul a{color:#c8ccd4;font-size:14px}
.footer ul a:hover{color:var(--accent)}
.footer-bottom{max-width:var(--maxw);margin:60px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-dim)}
.footer-mega{font-family:var(--display);font-size:clamp(80px, 18vw, 280px);line-height:0.85;letter-spacing:-0.02em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,0.18);margin-top:60px;text-align:center;user-select:none}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}

/* Cards & utility */
.card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s}
.card:hover{border-color:var(--line-strong);transform:translateY(-2px)}

.tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(255,255,255,0.04);border:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-mute)}
.tag.gold{color:var(--gold);border-color:rgba(212,168,90,0.35);background:rgba(212,168,90,0.08)}
.tag.cyan{color:var(--accent);border-color:rgba(0,224,255,0.3);background:rgba(0,224,255,0.06)}

/* Marquee */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;background:var(--bg-1)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:marq 38s linear infinite;font-family:var(--display);font-size:32px;text-transform:uppercase;letter-spacing:-0.005em;color:var(--text)}
.marquee-track .star{color:var(--accent);font-size:24px;align-self:center}
@keyframes marq{to{transform:translateX(-50%)}}

/* Image placeholder slot */
.slot{
  position:relative;width:100%;height:100%;
  background:
    repeating-linear-gradient(135deg, rgba(0,224,255,0.04) 0 14px, rgba(0,224,255,0.07) 14px 28px),
    var(--bg-2);
  border:1px dashed rgba(0,224,255,0.25);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-mute);
  text-align:center;padding:20px;
}
.slot::before{content:"○";position:absolute;top:10px;left:12px;color:var(--accent);font-size:14px}
.slot small{display:block;color:var(--text-dim);margin-top:6px;font-size:9px}

/* Page hero common */
.page-hero{padding:180px var(--pad) 100px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-hero .crumbs{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-mute);margin-bottom:24px}
.page-hero h1{font-size:clamp(56px,10vw,160px)}
.page-hero .lead{margin-top:24px;max-width:60ch}
.page-hero-bg{position:absolute;inset:0;pointer-events:none;opacity:0.5}
.page-hero-bg::before{
  content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(0,224,255,0.15), transparent 70%);
  filter:blur(40px);
}

/* Section title */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:60px;flex-wrap:wrap}
.section-head .num{font-family:var(--mono);font-size:12px;letter-spacing:0.18em;color:var(--text-mute);display:block;margin-bottom:14px}

/* Form */
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-mute)}
.field input,.field select,.field textarea{
  background:var(--bg-2);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;color:var(--text);font:inherit;
  transition:all .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#0e1820;box-shadow:0 0 0 4px rgba(0,224,255,0.1)}
.field textarea{resize:vertical;min-height:120px}

/* Helpers */
.divider{height:1px;background:var(--line);margin:80px 0}
.spacer-sm{height:40px}.spacer-md{height:80px}.spacer-lg{height:140px}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#1c222d;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#2a3340}

@keyframes pulse{50%{opacity:0.4}}

/* ============= FLOATING ACTIONS ============= */
.float-actions{position:fixed;right:20px;bottom:90px;z-index:80;display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.fa-btn{
  position:relative;width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,13,19,0.85);backdrop-filter:blur(20px);
  color:#fff;cursor:pointer;transition:all .25s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 12px 30px rgba(0,0,0,0.35);
  text-decoration:none;
}
.fa-btn:hover{transform:translateY(-2px) scale(1.05)}
.fa-btn .fa-tip{
  position:absolute;right:64px;top:50%;transform:translateY(-50%);
  background:rgba(10,13,19,0.92);border:1px solid rgba(255,255,255,0.14);
  padding:8px 14px;border-radius:999px;color:#fff;
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  opacity:0;pointer-events:none;transition:all .2s;white-space:nowrap;
}
.fa-btn:hover .fa-tip{opacity:1;transform:translateY(-50%) translateX(-4px)}
.fa-wa{background:#1faa54;border-color:#1faa54;color:#fff}
.fa-wa:hover{background:#23c060}
.fa-wa .fa-pulse{
  position:absolute;inset:-4px;border-radius:50%;border:2px solid #1faa54;
  animation:waPulse 2s ease-out infinite;pointer-events:none;
}
@keyframes waPulse{0%{opacity:0.8;transform:scale(1)}100%{opacity:0;transform:scale(1.6)}}
.fa-review{color:var(--gold)}
.fa-review:hover{border-color:var(--gold);background:rgba(212,168,90,0.12)}
@media(max-width:600px){.float-actions{right:14px;bottom:80px;gap:10px}.fa-btn{width:48px;height:48px}.fa-btn .fa-tip{display:none}}

/* ============= REVIEW MODAL ============= */
.review-modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(2,4,8,0.78);backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;padding:20px;
  opacity:0;transition:opacity .25s;
}
.review-modal.open{display:flex;opacity:1}
.rm-card{
  background:linear-gradient(180deg,#0e1218,#0a0d13);
  border:1px solid rgba(255,255,255,0.12);border-radius:22px;
  padding:40px;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;
  position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(0,224,255,0.08);
  animation:rmIn .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes rmIn{from{opacity:0;transform:translateY(20px) scale(0.97)}to{opacity:1;transform:none}}
.rm-close{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid var(--line);color:var(--text-mute);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.rm-close:hover{color:#fff;border-color:rgba(255,255,255,0.3)}
.rm-card h3{margin-top:14px;font-size:clamp(32px,4vw,48px)}
.rm-form{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.star-pick{display:flex;gap:4px}
.star-pick button{font-size:34px;color:rgba(255,255,255,0.18);background:transparent;border:0;cursor:pointer;transition:all .15s;padding:2px 4px;line-height:1}
.star-pick button:hover,.star-pick button.hover,.star-pick button.on{color:var(--gold);transform:scale(1.1)}

/* Noise overlay */
.noise{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:0.04;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.7'/></svg>")}
