

:root {
  --bg:    #0a0705;
  --s1:    #130e09;
  --s2:    #1e1610;
  --s3:    #2a1f14;
  --s4:    #352818;
  --b1:    rgba(255,255,255,0.06);
  --b2:    rgba(255,255,255,0.11);
  --b3:    rgba(255,255,255,0.18);
  --crim:  #d42818;  --crim2: #f07828;
  --ember: #6a0a00;  --ember2:#f5c040;
  --gold:  #f5c040;  --gold2: #fff8a0;
  --sage:  #408870;  --sage2: #70c0a0;
  --plum:  #f07828;  --plum2: #ff9848;
  --steel: #4070a0;  --steel2:#80b0d8;
  --tx:    #f0e8d8;
  --mu:    rgba(240,232,216,.40);
  --mu2:   rgba(240,232,216,.65);
  --mu3:   rgba(240,232,216,.85);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--tx);font-family:'DM Sans',sans-serif;font-weight:300;min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 65% 50% at 10% 5%,rgba(212,40,24,.07) 0%,transparent 65%),
             radial-gradient(ellipse 55% 60% at 90% 90%,rgba(240,120,40,.06) 0%,transparent 65%),
             radial-gradient(ellipse 45% 45% at 50% 50%,rgba(212,40,24,.04) 0%,transparent 70%);}
.grain{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.88' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ── LOADER ── */
#loader{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:16px;}
.loader-logo{font-family:'Fraunces',serif;font-style:italic;font-size:42px;
  background:linear-gradient(115deg,var(--tx) 0%,var(--crim2) 50%,var(--gold2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.loader-spin{width:32px;height:32px;border:2px solid var(--b2);border-top-color:var(--crim);
  border-radius:50%;animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── NAV ── */
#app-nav{position:sticky;top:0;z-index:90;height:56px;display:none;align-items:center;gap:2px;padding:0 16px;
  background:rgba(6,5,10,.93);backdrop-filter:blur(20px);border-bottom:1px solid var(--b1);}
.nav-logo{font-family:'Fraunces',serif;font-style:italic;font-size:22px;margin-right:12px;
  background:linear-gradient(115deg,var(--tx) 0%,var(--crim2) 50%,var(--gold2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;cursor:pointer;}
.nav-links{display:flex;gap:0;flex:1;overflow-x:auto;}
.nav-links::-webkit-scrollbar{display:none}
.np{height:56px;padding:0 12px;background:none;border:none;border-bottom:2px solid transparent;
  font-family:'DM Sans',sans-serif;font-size:10px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mu);cursor:pointer;transition:all .25s;white-space:nowrap;}
.np:hover{color:var(--mu2);}
.np.on{color:var(--crim2);border-bottom-color:var(--crim);}
.nav-user{margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav-score-badge{background:linear-gradient(135deg,rgba(200,64,96,.3),rgba(216,96,48,.2));
  border:1px solid rgba(200,64,96,.4);border-radius:12px;padding:3px 10px;font-size:11px;
  display:flex;align-items:center;gap:5px;}
.nav-score-badge span{color:var(--crim2);}
.nav-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--crim),var(--plum));
  display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;}
.nav-signout{background:none;border:1px solid var(--b2);border-radius:4px;padding:4px 10px;
  font-family:'DM Sans',sans-serif;font-size:10px;letter-spacing:.1em;color:var(--mu);cursor:pointer;
  text-transform:uppercase;transition:all .25s;}
.nav-signout:hover{border-color:var(--crim);color:var(--crim2);}

/* ── SCREENS ── */
.scr{display:none;position:relative;z-index:1;}
.scr.on{display:block;animation:fadeUp .3s ease;}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── MEMBERSHIP ── */
#s-membership.on{display:block;}
.mem-card{background:var(--s1);border:1px solid var(--b2);border-radius:12px;overflow:hidden;position:relative;display:flex;flex-direction:column;}
.mem-card-featured{border-color:rgba(200,64,96,.5);box-shadow:0 0 0 1px rgba(200,64,96,.2),0 8px 32px rgba(200,64,96,.12);}
.mem-featured-badge{position:absolute;top:12px;right:12px;font-size:9px;letter-spacing:.15em;text-transform:uppercase;background:linear-gradient(135deg,var(--crim),#a02040);color:var(--tx);padding:3px 10px;border-radius:8px;}
.mem-card-header{padding:22px 20px 16px;background:rgba(255,255,255,.02);border-bottom:1px solid var(--b1);}
.mem-tier-icon{font-size:28px;margin-bottom:8px;}
.mem-tier-name{font-family:'Fraunces',serif;font-style:italic;font-size:22px;font-weight:300;color:var(--tx);margin-bottom:4px;}
.mem-tier-price{font-size:26px;color:var(--tx);font-weight:300;}
.mem-tier-price span{font-size:13px;color:var(--mu);}
.mem-card-body{padding:18px 20px;flex:1;}
.mem-feature{font-size:12px;color:var(--mu2);padding:5px 0;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:8px;}
.mem-feature:last-child{border-bottom:none;}
.mem-feature.on{color:var(--tx);}
.mem-feature.on::before{content:'✓';color:var(--sage2);font-size:11px;flex-shrink:0;}
.mem-feature.off{opacity:.4;}
.mem-feature.off::before{content:'–';color:var(--mu);font-size:11px;flex-shrink:0;}
.mem-card-footer{padding:14px 20px 18px;}
.mem-current-tag{text-align:center;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--mu2);padding:10px;background:var(--s2);border-radius:6px;}

/* ── DATE NIGHT BUCKET ROWS & SLIDERS ── */
.dn-bucket-row{transition:opacity .2s;}
.dn-bucket-row.disabled{opacity:.35;}
.dn-bucket-row.disabled .dn-pct-slider{pointer-events:none;}
.dn-bucket-row.disabled .dn-bucket-toggle{pointer-events:all;opacity:1;filter:grayscale(1);}
.dn-bucket-toggle{width:36px;height:36px;border-radius:8px;border:2px solid var(--b2);
  background:var(--s2);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;flex-shrink:0;}
.dn-bucket-toggle.active{border-color:rgba(200,64,96,.5);background:rgba(200,64,96,.1);}
.dn-bucket-toggle:not(.active){filter:grayscale(1);opacity:.6;}
.dn-pct-slider{-webkit-appearance:none;height:5px;border-radius:3px;
  background:linear-gradient(90deg,var(--crim) var(--val,33%),var(--s3) var(--val,33%));
  cursor:pointer;outline:none;}
.dn-pct-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;
  border-radius:50%;background:var(--crim2);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.4);}
.dn-pct-slider:disabled{opacity:.3;cursor:default;}
#dn-pct-total.over{color:var(--crim2);}

.dn-dur-btn.active{background:linear-gradient(135deg,rgba(200,64,96,.25),rgba(216,96,48,.15));border-color:var(--crim);color:var(--crim2);}

/* ── DATE NIGHT CHECKLIST & MODAL ── */
.dn-activity-check{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--s1);border:1px solid var(--b2);border-radius:8px;margin-bottom:6px;transition:opacity .2s;}
.dn-activity-check.deselected{opacity:.4;}
.dn-check-box{width:20px;height:20px;border:2px solid var(--b2);border-radius:4px;flex-shrink:0;margin-top:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;background:var(--s2);}
.dn-check-box.checked{background:linear-gradient(135deg,var(--crim),#a02040);border-color:var(--crim);}
.dn-check-box.checked::after{content:'✓';color:#fff;font-size:12px;}
.dn-activity-check-body{flex:1;min-width:0;}
.dn-check-title{font-size:13px;color:var(--tx);margin-bottom:2px;}
.dn-check-dir{font-size:11px;color:var(--crim2);margin-bottom:3px;}
.dn-check-score{font-size:11px;color:var(--mu2);}
.dn-check-score strong{color:var(--gold2);}

/* Modal */
.dn-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;}
.dn-modal{background:var(--s1);border:1px solid var(--b2);border-radius:14px;padding:28px;max-width:420px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.5);}
.dn-modal h3{font-family:'Fraunces',serif;font-size:22px;font-weight:300;margin-bottom:6px;}
.dn-modal-field{margin-bottom:16px;}
.dn-modal-field label{display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:6px;}
.dn-modal-field input{width:100%;background:var(--s2);border:1px solid var(--b2);border-radius:6px;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--tx);box-sizing:border-box;}
.dn-modal-field input:focus{outline:none;border-color:var(--crim2);}

/* ── ABOUT ── */
#s-about.on{display:block;}
#s-legal.on{display:block;}
.about-hero{text-align:center;padding:48px 24px 36px;background:linear-gradient(160deg,rgba(106,10,0,.25),rgba(200,64,96,.08),transparent);border-bottom:1px solid var(--b1);margin-bottom:0;}
.about-hero h1{font-family:'Fraunces',serif;font-size:clamp(32px,6vw,56px);font-weight:200;font-style:italic;color:var(--tx);line-height:1.1;margin-bottom:12px;}
.about-hero h1 em{color:var(--crim2);font-style:italic;}
.about-hero p{font-size:14px;color:var(--mu2);max-width:480px;margin:0 auto;line-height:1.7;}
.about-pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;padding:32px 24px;max-width:960px;margin:0 auto;}
.about-pillar{background:var(--s1);border:1px solid var(--b2);border-radius:14px;padding:24px;position:relative;overflow:hidden;}
.about-pillar::before{content:'';position:absolute;inset:0;opacity:.04;background:var(--gradient);}
.about-pillar-num{font-family:'Fraunces',serif;font-size:48px;font-weight:200;font-style:italic;color:var(--crim2);opacity:.6;line-height:1;margin-bottom:8px;}
.about-pillar h3{font-family:'Fraunces',serif;font-size:20px;font-weight:300;color:var(--tx);margin-bottom:10px;}
.about-pillar p{font-size:13px;color:var(--mu2);line-height:1.75;}
.about-pillar .about-price{display:inline-block;background:rgba(200,64,96,.12);border:1px solid rgba(200,64,96,.3);border-radius:20px;padding:4px 12px;font-size:11px;color:var(--crim2);letter-spacing:.08em;margin-top:10px;}
.about-body{max-width:720px;margin:0 auto;padding:0 24px 48px;}
.about-section{background:var(--s1);border:1px solid var(--b1);border-radius:12px;padding:24px;margin-bottom:16px;}
.about-section h4{font-family:'Fraunces',serif;font-size:17px;font-weight:300;color:var(--gold2);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.about-section p{font-size:13px;color:var(--mu2);line-height:1.8;margin-bottom:8px;}
.about-section p:last-child{margin-bottom:0;}
.about-founder{background:linear-gradient(135deg,rgba(200,64,96,.08),rgba(106,10,0,.12));border:1px solid rgba(200,64,96,.2);border-radius:12px;padding:24px;margin-bottom:16px;}
.about-cta{text-align:center;padding:32px 24px;background:var(--s1);border:1px solid var(--b2);border-radius:14px;margin-bottom:24px;}
.about-cta h3{font-family:'Fraunces',serif;font-size:24px;font-weight:200;font-style:italic;color:var(--tx);margin-bottom:8px;}
.about-cta p{font-size:13px;color:var(--mu2);margin-bottom:18px;line-height:1.7;}
.about-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(200,64,96,.1);border:1px solid rgba(200,64,96,.25);border-radius:20px;padding:5px 14px;font-size:11px;color:var(--crim2);letter-spacing:.08em;margin:3px;}

/* ── SEARCH PREFS ── */
.pref-check{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--s2);border:1px solid var(--b2);border-radius:6px;cursor:pointer;font-size:12px;color:var(--mu2);transition:background .15s,border-color .15s,color .15s;}
.pref-check:has(input:checked){background:rgba(200,64,96,.15);border-color:rgba(200,64,96,.4);color:var(--tx);}
.pref-check input{width:13px;height:13px;accent-color:var(--crim2);cursor:pointer;}

/* ── MESSAGING ── */
.msg-icon-btn{position:relative;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--mu2);transition:color .2s;}
.msg-icon-btn:hover{color:var(--tx);}
.msg-icon-btn svg{width:20px;height:20px;}
.msg-unread-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%;background:#fff;border:1.5px solid var(--s1);display:none;}
.msg-unread-dot.on{display:block;}

/* Drawer */
.msg-drawer{position:fixed;top:0;right:-380px;width:380px;max-width:100vw;height:100vh;background:var(--s1);border-left:1px solid var(--b2);z-index:500;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px rgba(0,0,0,.4);}
.msg-drawer.open{right:0;}
.msg-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--b1);flex-shrink:0;}
.msg-drawer-header h3{font-family:'Fraunces',serif;font-size:18px;font-weight:300;margin:0;}
.msg-close-btn{background:none;border:none;color:var(--mu);cursor:pointer;font-size:20px;padding:4px;line-height:1;}
.msg-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:499;display:none;}
.msg-overlay.on{display:block;}

/* Conversation list */
.msg-conv-list{flex:1;overflow-y:auto;}
.msg-conv-item{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--b1);cursor:pointer;transition:background .15s;}
.msg-conv-item:hover{background:var(--s2);}
.msg-conv-item.unread{background:rgba(200,64,96,.06);}
.msg-conv-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--crim),var(--plum));display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;color:#fff;}
.msg-conv-body{flex:1;min-width:0;}
.msg-conv-name{font-size:13px;color:var(--tx);margin-bottom:2px;display:flex;align-items:center;justify-content:space-between;}
.msg-conv-name span{font-size:10px;color:var(--mu);}
.msg-conv-preview{font-size:11px;color:var(--mu2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.msg-conv-item.unread .msg-conv-preview{color:var(--tx);font-weight:500;}
.msg-unread-badge{width:8px;height:8px;border-radius:50%;background:var(--crim2);flex-shrink:0;}
.msg-no-convs{padding:32px 18px;text-align:center;color:var(--mu);font-size:13px;line-height:1.7;}

/* Thread view */
.msg-thread{display:flex;flex-direction:column;height:100%;}
.msg-thread-header{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--b1);flex-shrink:0;}
.msg-back-btn{background:none;border:none;color:var(--mu2);cursor:pointer;font-size:18px;padding:2px 6px;}
.msg-thread-name{font-size:14px;color:var(--tx);}
.msg-thread-messages{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:10px;}
.msg-bubble{max-width:80%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5;}
.msg-bubble.mine{background:linear-gradient(135deg,rgba(200,64,96,.35),rgba(216,96,48,.2));border:1px solid rgba(200,64,96,.3);align-self:flex-end;color:var(--tx);border-bottom-right-radius:3px;}
.msg-bubble.theirs{background:var(--s2);border:1px solid var(--b2);align-self:flex-start;color:var(--tx);border-bottom-left-radius:3px;}
.msg-bubble-time{font-size:9px;color:var(--mu);margin-top:4px;text-align:right;}
.msg-thread-input{display:flex;gap:8px;padding:12px 18px;border-top:1px solid var(--b1);flex-shrink:0;}
.msg-thread-input textarea{flex:1;background:var(--s2);border:1px solid var(--b2);border-radius:8px;padding:10px 12px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--tx);resize:none;height:40px;max-height:120px;overflow-y:auto;line-height:1.4;}
.msg-thread-input textarea:focus{outline:none;border-color:var(--crim2);}
.msg-send-btn{background:linear-gradient(135deg,var(--crim),#a02040);border:none;border-radius:8px;color:#fff;cursor:pointer;padding:0 14px;font-size:16px;flex-shrink:0;}
.msg-send-btn:hover{opacity:.85;}
.msg-new-btn{margin:14px 18px;width:calc(100% - 36px);}

/* ── AUTH ── */
#s-auth{min-height:100vh;display:none;align-items:center;justify-content:center;padding:24px;}
#s-auth.on{display:flex;}
.auth-card{background:var(--s1);border:1px solid var(--b2);border-radius:12px;padding:40px 36px;
  width:100%;max-width:420px;position:relative;overflow:hidden;}
.auth-card::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(200,64,96,.08),transparent 70%);}
.auth-logo{font-family:'Fraunces',serif;font-style:italic;font-size:38px;text-align:center;margin-bottom:6px;
  background:linear-gradient(135deg,var(--tx),var(--crim2) 50%,var(--gold2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.auth-tagline{text-align:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--mu);margin-bottom:32px;}
.auth-tabs{display:flex;background:var(--s2);border-radius:6px;margin-bottom:24px;overflow:hidden;}
.auth-tab{flex:1;padding:10px;text-align:center;font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--mu);cursor:pointer;transition:all .25s;border:none;background:none;font-family:'DM Sans',sans-serif;}
.auth-tab.on{background:linear-gradient(135deg,rgba(200,64,96,.25),rgba(216,96,48,.15));color:var(--crim2);}
.auth-field{margin-bottom:16px;}
.auth-field label{display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:6px;}
.auth-field input{width:100%;background:var(--s2);border:1px solid var(--b2);border-radius:6px;
  padding:12px 14px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--tx);transition:border .2s;}
.auth-field input:focus{outline:none;border-color:var(--crim);}
.auth-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--crim),#a02040);border:none;
  border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;letter-spacing:.15em;
  text-transform:uppercase;color:var(--tx);cursor:pointer;transition:opacity .2s;margin-bottom:12px;}
.auth-btn:hover{opacity:.88;}
.auth-divider{text-align:center;font-size:11px;color:var(--mu);margin:12px 0;position:relative;}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:var(--b2);}
.auth-divider::before{left:0} .auth-divider::after{right:0}
.google-btn{width:100%;padding:12px;background:var(--s2);border:1px solid var(--b2);border-radius:6px;
  font-family:'DM Sans',sans-serif;font-size:12px;letter-spacing:.1em;color:var(--mu2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;transition:all .25s;}
.google-btn:hover{border-color:var(--b3);color:var(--tx);}
.google-icon{width:18px;height:18px;}
.auth-err{color:var(--crim2);font-size:12px;margin-top:10px;min-height:18px;}
.auth-note{font-size:11px;color:var(--mu);margin-top:16px;text-align:center;line-height:1.6;}

/* ── ONBOARDING ── */
#s-onboarding{min-height:100vh;display:none;align-items:center;justify-content:center;padding:24px;}
#s-onboarding.on{display:flex;}
.ob-card{background:var(--s1);border:1px solid var(--b2);border-radius:12px;padding:40px 36px;
  width:100%;max-width:460px;position:relative;overflow:hidden;}
.ob-card::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(128,80,168,.1),transparent 70%);}
.ob-logo{font-family:'Fraunces',serif;font-style:italic;font-size:32px;text-align:center;margin-bottom:4px;
  background:linear-gradient(135deg,var(--tx),var(--plum2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.ob-sub{text-align:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:28px;}
.ob-field{margin-bottom:16px;}
.ob-field label{display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:6px;}
.ob-field input,.ob-field select{width:100%;background:var(--s2);border:1px solid var(--b2);border-radius:6px;
  padding:12px 14px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--tx);transition:border .2s;}
.ob-field input:focus,.ob-field select:focus{outline:none;border-color:var(--plum);}
.ob-field select option{background:var(--s2);}
.ob-hint{font-size:11px;color:var(--mu);margin-top:5px;line-height:1.5;}
.ob-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--plum),#5030a0);border:none;
  border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;letter-spacing:.15em;
  text-transform:uppercase;color:var(--tx);cursor:pointer;transition:opacity .2s;margin-top:8px;}
.ob-btn:hover{opacity:.88;}
.ob-err{color:var(--crim2);font-size:12px;margin-top:10px;min-height:18px;}
.ob-privacy{background:var(--s2);border:1px solid var(--b1);border-radius:6px;padding:12px 14px;
  font-size:11px;color:var(--mu);line-height:1.6;margin-bottom:16px;}
.ob-privacy strong{color:var(--mu2);}

/* ── COMMON LAYOUT ── */
.page{padding:28px 20px;max-width:1200px;margin:0 auto;}
.page-hero{background:var(--s1);border:1px solid var(--b1);border-radius:10px;
  padding:24px 28px;margin-bottom:24px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 100% at 0 50%,rgba(200,64,96,.07),transparent 65%);}
.page-hero h2{font-family:'Fraunces',serif;font-size:clamp(20px,3vw,32px);font-weight:300;margin-bottom:6px;}
.page-hero h2 em{font-style:italic;color:var(--crim2);}
.page-hero p{font-size:12px;color:var(--mu2);line-height:1.7;max-width:540px;}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:20px;}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:20px;}
.card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:20px;}
.card-title{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);margin-bottom:12px;}
.stat-big{font-family:'Fraunces',serif;font-size:36px;font-weight:300;}
.stat-sub{font-size:11px;color:var(--mu2);margin-top:4px;}
.btn{padding:10px 20px;border:none;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:11px;
  font-weight:400;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .25s;}
.btn-pri{background:linear-gradient(135deg,var(--crim),#a02040);color:var(--tx);}
.btn-pri:hover{opacity:.85;}
.btn-sec{background:var(--s3);border:1px solid var(--b2);color:var(--mu2);}
.btn-sec:hover{border-color:var(--b3);color:var(--tx);}
.btn-gold{background:linear-gradient(135deg,var(--gold),#a06010);color:var(--bg);}
.btn-sage{background:linear-gradient(135deg,var(--sage),#306050);color:var(--tx);}
.btn-plum{background:linear-gradient(135deg,var(--plum),#5030a0);color:var(--tx);}
.section-title{font-family:'Fraunces',serif;font-size:22px;font-weight:300;margin-bottom:16px;}
.section-title em{font-style:italic;color:var(--plum2);}
.field-row{margin-bottom:14px;}
.field-row label{display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:6px;}
.field-row input,.field-row select,.field-row textarea{width:100%;background:var(--s2);border:1px solid var(--b2);
  border-radius:6px;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--tx);}
.field-row input:focus,.field-row select:focus,.field-row textarea:focus{outline:none;border-color:var(--crim);}
.field-row select option{background:var(--s2);}
.field-row textarea{resize:vertical;min-height:80px;}

/* ── DASHBOARD ── */
#s-dashboard .dash-welcome{font-family:'Fraunces',serif;font-size:clamp(24px,4vw,40px);
  font-weight:300;margin-bottom:4px;}
#s-dashboard .dash-welcome em{font-style:italic;color:var(--crim2);}
.happiness-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;}
.happiness-ring{position:relative;width:130px;height:130px;}
.happiness-ring svg{transform:rotate(-90deg);}
.happiness-ring-bg{fill:none;stroke:var(--s3);stroke-width:8;}
.happiness-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;
  stroke:url(#hring-grad);transition:stroke-dasharray 1s ease;
  stroke-dasharray:0 339.29;}
.happiness-ring-num{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;}
.happiness-ring-num .num{font-family:'Fraunces',serif;font-size:30px;font-weight:300;}
.happiness-ring-num .lbl{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);}
.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:20px;}
.qa-btn{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:16px 18px;
  cursor:pointer;transition:all .3s;text-align:left;}
.qa-btn:hover{border-color:var(--b3);transform:translateY(-2px);}
.qa-btn .qa-icon{font-size:24px;margin-bottom:8px;}
.qa-btn .qa-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mu2);}
.qa-btn .qa-desc{font-size:11px;color:var(--mu);margin-top:4px;line-height:1.5;}

/* ── ADMIN ── */
.adm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:24px;}
.adm-stat{background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:16px 18px;}
.adm-stat .as-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);margin-bottom:6px;}
.adm-stat .as-val{font-family:'Fraunces',serif;font-size:28px;}
.adm-stat .as-sub{font-size:11px;color:var(--mu2);margin-top:3px;}
.adm-section{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:20px;margin-bottom:20px;}
/* Metrics dashboard */
.adm-mtab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-size:12px;color:var(--mu);cursor:pointer;white-space:nowrap;transition:all .2s;}
.adm-mtab:hover{color:var(--tx);}
.adm-mtab.on{color:var(--gold2);border-bottom-color:var(--gold2);}
.tq-filter.on{background:rgba(200,168,48,.15);border-color:var(--gold2);color:var(--gold2);}
.adm-mview{animation:fadein .2s ease;}
.adm-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;}
.adm-kpi{background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:14px 16px;text-align:center;}
.kpi-val{font-size:26px;font-weight:700;font-family:'Fraunces',serif;line-height:1.1;margin-bottom:4px;}
.kpi-lbl{font-size:11px;color:var(--mu2);letter-spacing:.06em;}
.kpi-sub{font-size:10px;color:var(--mu);margin-top:2px;}
.adm-list-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--b1);font-size:12px;}
.adm-list-row:last-child{border-bottom:none;}
.adm-list-row:hover{background:rgba(255,255,255,.03);}
/* P&L Simulator */
.pnl-slider-group{display:flex;flex-direction:column;gap:4px;}
.pnl-slider-label{font-size:12px;color:var(--tx);display:flex;justify-content:space-between;align-items:center;}
.pnl-val{color:var(--gold2);font-weight:600;font-family:'Fraunces',serif;}
.pnl-hint{font-size:10px;color:var(--mu);line-height:1.4;}
.pnl-range{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:var(--b2);outline:none;cursor:pointer;}
.pnl-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--crim2);cursor:pointer;transition:transform .1s;}
.pnl-range::-webkit-slider-thumb:hover{transform:scale(1.3);}
.pnl-sum{text-align:center;flex:1;min-width:80px;}
.pnl-sum-val{font-size:22px;font-weight:700;font-family:'Fraunces',serif;line-height:1.1;}
.pnl-sum-lbl{font-size:10px;color:var(--mu);margin-top:3px;letter-spacing:.05em;}
.pnl-divider{width:1px;background:var(--b1);margin:4px 0;}
.pnl-row{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--b1);font-size:12px;}
.pnl-row:last-child{border-bottom:none;}
.pnl-row-lbl{color:var(--mu2);display:flex;align-items:center;gap:6px;}
.pnl-row-amt{font-weight:600;font-family:'Fraunces',serif;}
.pnl-row-sub{font-size:10px;color:var(--mu);}
.pnl-free-ok{color:var(--sage2);}
.pnl-free-warn{color:var(--gold2);}
.pnl-free-over{color:var(--crim2);}
.pnl-fc-row{display:grid;grid-template-columns:60px repeat(12,1fr);font-size:10px;border-bottom:1px solid var(--b1);}
.pnl-fc-row>div{padding:6px 4px;text-align:right;white-space:nowrap;}
.pnl-fc-row>div:first-child{text-align:left;color:var(--mu);font-size:9px;letter-spacing:.08em;text-transform:uppercase;}
.pnl-fc-head{font-size:9px;color:var(--mu);background:rgba(0,0,0,.2);}
.pnl-fc-profit.pos{color:var(--sage2);}
.pnl-fc-profit.neg{color:var(--crim2);}
#adm-cmd-output::-webkit-scrollbar{width:4px;}
#adm-cmd-output::-webkit-scrollbar-track{background:transparent;}
#adm-cmd-output::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px;}
#adm-cmd-input:focus{outline:none;border-color:rgba(200,168,48,.5);}
#adm-command-wrap .btn-sec{font-size:10px;padding:5px 10px;}
.adm-table{width:100%;border-collapse:collapse;font-size:12px;}
.adm-table th{text-align:left;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mu);
  padding:8px 10px;border-bottom:1px solid var(--b1);}
.adm-table td{padding:10px 10px;border-bottom:1px solid var(--b1);color:var(--mu2);}
.adm-table tr:hover td{background:rgba(255,255,255,.02);}
.happiness-bars{display:flex;flex-direction:column;gap:8px;}
.h-bar-row{display:flex;align-items:center;gap:10px;}
.h-bar-label{font-size:11px;width:80px;color:var(--mu2);}
.h-bar-track{flex:1;height:8px;background:var(--s3);border-radius:4px;overflow:hidden;}
.h-bar-fill{height:100%;border-radius:4px;transition:width 1s ease;}
.h-bar-val{font-size:11px;color:var(--mu);width:30px;text-align:right;}
.seed-section{background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:16px;margin-bottom:16px;}
.seed-note{font-size:11px;color:var(--mu);line-height:1.7;margin-bottom:12px;}

/* ── COUPLES ── */
.exp-mode-card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:22px;margin-bottom:20px;}
.exp-mode-card h3{font-family:'Fraunces',serif;font-size:20px;font-weight:300;margin-bottom:4px;}
.exp-mode-card p{font-size:12px;color:var(--mu2);line-height:1.7;margin-bottom:16px;}
.exp-mode-opts{display:flex;flex-direction:column;gap:10px;}
.exp-opt{display:flex;align-items:flex-start;gap:14px;background:var(--s2);border:1px solid var(--b1);
  border-radius:8px;padding:14px 16px;cursor:pointer;transition:all .25s;}
.exp-opt.selected{border-color:var(--plum);background:rgba(128,80,168,.12);}
.exp-opt-icon{font-size:22px;flex-shrink:0;}
.exp-opt-info .exp-opt-label{font-size:13px;font-weight:500;margin-bottom:3px;}
.exp-opt-info .exp-opt-desc{font-size:11px;color:var(--mu2);line-height:1.5;}
.couple-link-card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:22px;}
.couple-link-card h3{font-family:'Fraunces',serif;font-size:20px;font-weight:300;margin-bottom:12px;}

/* ── DESIRE MAP ── */
.dm-category-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px;}
.dm-tab{padding:7px 14px;background:var(--s2);border:1px solid var(--b1);border-radius:20px;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mu);cursor:pointer;transition:all .25s;}
.dm-tab.on{background:rgba(200,64,96,.2);border-color:var(--crim);color:var(--crim2);}
.dm-items-grid{display:flex;flex-direction:column;gap:10px;}
.dm-item{background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:14px 16px;
  transition:border .2s;}
.dm-item:hover{border-color:var(--b2);}
.dm-item-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.dm-item-name{font-size:13px;flex:1;}
.dm-item-badge{font-size:10px;padding:2px 8px;border-radius:10px;}
.dm-score-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.dm-score-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mu);width:60px;}
.dm-slider{flex:1;-webkit-appearance:none;height:4px;border-radius:2px;background:var(--s3);cursor:pointer;}
.dm-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;
  background:var(--crim);cursor:pointer;}
.dm-score-val{font-family:'Fraunces',serif;font-size:18px;width:24px;text-align:center;}
.dm-toggles{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.dm-toggle{padding:4px 10px;font-size:10px;background:var(--s3);border:1px solid var(--b1);
  border-radius:4px;cursor:pointer;transition:all .2s;color:var(--mu);}
.dm-toggle.on{background:rgba(64,136,112,.2);border-color:var(--sage);color:var(--sage2);}

/* ── DATE NIGHT ── */
.dn-hero{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:24px;margin-bottom:20px;
  background-image:radial-gradient(ellipse 60% 80% at 0 50%,rgba(216,96,48,.08),transparent 70%);}
.dn-mode-indicator{display:flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--b1);
  border-radius:8px;padding:12px 16px;margin-bottom:20px;}
.dn-mode-icon{font-size:20px;}
.dn-mode-text{font-size:12px;color:var(--mu2);}
.dn-mode-text strong{color:var(--tx);}
.dn-script{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:24px;}
.dn-activity{background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:16px;margin-bottom:12px;}
.dn-activity-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.dn-activity-num{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--crim),#a02040);
  display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;}
.dn-activity-name{font-size:14px;}
.dn-activity-score{margin-left:auto;font-family:'Fraunces',serif;font-size:18px;color:var(--gold2);}
.dn-activity-desc{font-size:12px;color:var(--mu2);line-height:1.7;}
.dn-bridge-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(64,136,112,.15);
  border:1px solid var(--sage);border-radius:4px;padding:3px 8px;font-size:10px;color:var(--sage2);margin-top:6px;}

/* ── DISCOVER (Profile Rating) ── */
.discover-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;height:calc(100vh - 56px);overflow:hidden;}
@media(max-width:768px){.discover-wrap{grid-template-columns:1fr;height:auto;}}
.disc-photo-side{background:var(--s1);position:relative;overflow:hidden;min-height:400px;}
.disc-photo-img{width:100%;height:100%;object-fit:cover;display:block;}
.disc-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--s2),var(--s3));font-size:64px;color:var(--mu);}
.disc-ai-badge{position:absolute;top:14px;left:14px;padding:5px 10px;border-radius:6px;font-size:10px;
  letter-spacing:.1em;backdrop-filter:blur(8px);display:flex;align-items:center;gap:6px;}
.disc-ai-ok{background:rgba(64,136,112,.6);border:1px solid var(--sage);}
.disc-ai-warn{background:rgba(200,64,96,.5);border:1px solid var(--crim);}
.disc-photo-nav{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;}
.disc-photo-dot{width:7px;height:7px;border-radius:50%;background:var(--b3);cursor:pointer;transition:all .2s;}
.disc-photo-dot.on{background:var(--tx);}
.disc-info-side{overflow-y:auto;padding:24px 20px 120px;background:var(--bg);display:flex;flex-direction:column;}
.disc-profile-name{font-family:'Fraunces',serif;font-size:28px;font-weight:300;margin-bottom:4px;}
.disc-profile-meta{font-size:12px;color:var(--mu2);margin-bottom:16px;}
.disc-compat{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.disc-compat-tag{padding:4px 10px;background:rgba(128,80,168,.2);border:1px solid rgba(128,80,168,.4);
  border-radius:10px;font-size:10px;color:var(--plum2);}
.disc-top5{background:linear-gradient(135deg,rgba(200,168,48,.2),rgba(232,192,96,.1));
  border:1px solid var(--gold);border-radius:8px;padding:10px 14px;margin-bottom:16px;
  font-size:11px;color:var(--gold2);display:flex;align-items:center;gap:8px;}
.disc-rate-panel{position:fixed;bottom:0;right:0;width:50%;background:rgba(13,11,18,.97);
  backdrop-filter:blur(20px);border-top:1px solid var(--b2);padding:16px 20px;z-index:50;}
@media(max-width:768px){.disc-rate-panel{width:100%;}}
.disc-rate-row{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.disc-rate-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mu);width:120px;}
.disc-rate-slider{flex:1;-webkit-appearance:none;height:4px;border-radius:2px;background:var(--s3);cursor:pointer;}
.disc-rate-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--crim);}
.disc-rate-val{font-family:'Fraunces',serif;font-size:18px;width:24px;}
.disc-meet-btns{display:flex;gap:8px;}
.disc-meet-btn{flex:1;padding:8px;background:var(--s3);border:1px solid var(--b2);border-radius:6px;
  font-size:11px;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;color:var(--mu2);}
.disc-meet-btn.selected{background:rgba(64,136,112,.25);border-color:var(--sage);color:var(--sage2);}
.disc-action-btns{display:flex;gap:10px;margin-top:12px;}
.disc-pass-btn{flex:1;padding:12px;background:var(--s3);border:1px solid var(--b2);border-radius:8px;
  font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;color:var(--mu2);letter-spacing:.1em;
  text-transform:uppercase;transition:all .2s;}
.disc-pass-btn:hover{border-color:var(--crim);color:var(--crim2);}
.disc-like-btn{flex:1;padding:12px;background:linear-gradient(135deg,var(--crim),#a02040);border:none;
  border-radius:8px;font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;color:var(--tx);
  letter-spacing:.1em;text-transform:uppercase;transition:opacity .2s;}
.disc-like-btn:hover{opacity:.85;}

/* ── MATCHING ── */
.match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;}
.match-card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;overflow:hidden;
  transition:all .3s;cursor:pointer;}
.match-card:hover{border-color:var(--b3);transform:translateY(-3px);}
.match-card-photo{height:200px;background:linear-gradient(135deg,var(--s2),var(--s3));
  display:flex;align-items:center;justify-content:center;font-size:48px;position:relative;}
.match-trust-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--s3);}
.match-trust-fill{height:100%;background:linear-gradient(90deg,var(--crim),var(--gold));}
.match-card-body{padding:14px;}
.match-card-name{font-family:'Fraunces',serif;font-size:20px;font-weight:300;margin-bottom:3px;}
.match-card-meta{font-size:11px;color:var(--mu2);margin-bottom:8px;}
.match-compat{display:flex;align-items:center;gap:6px;}
.match-compat-bar{flex:1;height:5px;background:var(--s3);border-radius:3px;overflow:hidden;}
.match-compat-fill{height:100%;background:linear-gradient(90deg,var(--plum),var(--crim2));}
.match-compat-val{font-size:11px;color:var(--mu2);}
.match-tabs{display:flex;gap:0;background:var(--s2);border:1px solid var(--b1);border-radius:8px;
  margin-bottom:20px;overflow:hidden;}
.match-tab{flex:1;padding:10px;text-align:center;font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mu);cursor:pointer;transition:all .2s;border:none;background:none;font-family:'DM Sans',sans-serif;}
.match-tab.on{background:rgba(200,64,96,.15);color:var(--crim2);}

/* ── PROFILE ── */
.prof-wrap{max-width:600px;}
.prof-avatar-section{display:flex;align-items:center;gap:20px;margin-bottom:24px;}
.prof-avatar-big{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--crim),var(--plum));
  display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;}
.prof-avatar-info h3{font-family:'Fraunces',serif;font-size:22px;font-weight:300;margin-bottom:3px;}
.prof-avatar-info p{font-size:12px;color:var(--mu2);}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--sage);color:var(--tx);padding:10px 24px;border-radius:30px;font-size:12px;
  letter-spacing:.1em;z-index:999;transition:transform .3s ease;pointer-events:none;}
#toast.show{transform:translateX(-50%) translateY(0);}



/* Responsive */
@media(max-width:640px){
  .page{padding:16px 14px;}
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .adm-grid{grid-template-columns:repeat(2,1fr);}
  .disc-rate-panel{width:100%;}
}

/* ── Legal Section ── */
#s-legal .page { padding-bottom: 40px; }
.legal-section { margin-bottom: 22px; padding: 16px 18px; background: var(--s2); border: 1px solid var(--b1); border-radius: 10px; }
.legal-section h3 { font-family: 'Fraunces', serif; font-size: 15px; font-weight: 400; color: var(--crim2); margin: 0 0 8px; }
.legal-section p { font-size: 12px; color: var(--mu2); line-height: 1.8; margin: 0 0 8px; }
.legal-section p:last-child { margin-bottom: 0; }

