*{margin:0;padding:0;box-sizing:border-box}
:root{--pink:#FF3CAC;--violet:#784BA0;--blue:#2B86C5;--cream:#FFF8F0;--charcoal:#1A1A2E;--mint:#00F5D4;--gold:#FFD700}
body{background:var(--charcoal);color:var(--cream);font-family:'Syne',sans-serif;min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(120,75,160,0.3) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(255,60,172,0.2) 0%,transparent 50%),radial-gradient(ellipse at 60% 80%,rgba(43,134,197,0.2) 0%,transparent 50%);pointer-events:none;z-index:0}
.noise{position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1;opacity:0.4}
.container{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:0 24px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 40px;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,0.06);background:rgba(26,26,46,0.8)}
.nav-logo{font-family:'Playfair Display',serif;font-size:26px;font-weight:900;font-style:italic;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-right{display:flex;align-items:center;gap:20px}
.nav-link{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.4);text-decoration:none;transition:color 0.2s}
.nav-link:hover{color:rgba(255,255,255,0.85)}
.nav-quiz-btn{padding:8px 20px;background:linear-gradient(135deg,#FF3CAC,#784BA0);border:none;border-radius:100px;color:white;font-family:'Syne',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s}
.nav-quiz-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(255,60,172,0.4)}

/* HERO */
.hero{padding:140px 0 70px;text-align:center}
.hero-eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:22px;animation:fadeUp 0.7s ease forwards;opacity:0}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(52px,9vw,92px);font-weight:900;line-height:0.94;letter-spacing:-3px;margin-bottom:28px;animation:fadeUp 0.4s ease forwards 0.05s;opacity:0}
.hero-title em{font-style:italic;background:linear-gradient(135deg,#FF3CAC 0%,#784BA0 50%,#2B86C5 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:17px;color:rgba(255,255,255,0.5);max-width:520px;margin:0 auto 44px;line-height:1.7;animation:fadeUp 0.4s ease forwards 0.1s;opacity:0}
.category-strip{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:36px;animation:fadeUp 0.4s ease forwards 0.15s;opacity:0}
.cat-pill{padding:8px 18px;border:1px solid rgba(255,255,255,0.15);border-radius:100px;font-size:13px;font-family:'DM Mono',monospace;cursor:pointer;transition:all 0.2s;background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.7)}
.cat-pill:hover,.cat-pill.active{border-color:var(--pink);color:var(--pink);background:rgba(255,60,172,0.1)}

/* UPLOAD */
.upload-zone{border:2px dashed rgba(255,60,172,0.5);border-radius:24px;padding:48px 40px;text-align:center;cursor:pointer;transition:all 0.3s;background:rgba(255,255,255,0.02);animation:fadeUp 0.4s ease forwards 0.1s;opacity:0}
.upload-zone:hover{border-color:var(--pink);background:rgba(255,60,172,0.04)}
.upload-icon{font-size:40px;margin-bottom:14px}
.upload-label{font-size:20px;font-weight:700;margin-bottom:6px}
.upload-sub{font-size:13px;color:rgba(255,255,255,0.35);font-family:'DM Mono',monospace}
.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-top:20px}
.preview-item{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:1;animation:popIn 0.3s cubic-bezier(0.34,1.56,0.64,1)}
.preview-item img{width:100%;height:100%;object-fit:cover}
.preview-remove{position:absolute;top:7px;right:7px;width:24px;height:24px;background:rgba(0,0,0,0.7);border:none;border-radius:50%;color:white;cursor:pointer;font-size:14px;opacity:0;transition:opacity 0.2s;display:flex;align-items:center;justify-content:center}
.preview-item:hover .preview-remove{opacity:1}
.analyze-btn{display:block;width:100%;margin-top:28px;padding:19px;border:none;border-radius:16px;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);color:white;font-family:'Syne',sans-serif;font-size:18px;font-weight:700;cursor:pointer;transition:all 0.2s}
.analyze-btn:hover{transform:translateY(-2px);box-shadow:0 20px 60px rgba(255,60,172,0.3)}
.analyze-btn:disabled{opacity:0.45;cursor:not-allowed;transform:none;box-shadow:none}

/* LOADING */
.loading-state{text-align:center;padding:80px 0}
.loading-orb{width:80px;height:80px;margin:0 auto 24px;border-radius:50%;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);animation:pulse 1.5s ease-in-out infinite}
.loading-text{font-size:20px;font-weight:600;margin-bottom:8px}
.loading-sub{font-family:'DM Mono',monospace;font-size:12px;color:rgba(255,255,255,0.4);letter-spacing:2px}
.loading-steps{margin-top:28px;display:flex;flex-direction:column;gap:10px;max-width:280px;margin-left:auto;margin-right:auto}
.loading-step{display:flex;align-items:center;gap:12px;font-size:13px;color:rgba(255,255,255,0.35);font-family:'DM Mono',monospace}
.loading-step.active{color:var(--cream)}
.loading-step.done{color:var(--mint)}
.step-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.15);flex-shrink:0}
.loading-step.active .step-dot{background:var(--pink);animation:blink 0.8s ease-in-out infinite}
.loading-step.done .step-dot{background:var(--mint)}

/* RESULTS */
.results-header{text-align:center;padding:60px 0 44px}
.results-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:14px}
.results-title{font-family:'Playfair Display',serif;font-size:clamp(40px,8vw,64px);font-weight:900;font-style:italic;line-height:1;margin-bottom:10px}
.results-subtitle{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:3px;color:rgba(255,255,255,0.4)}
.score-ring-wrap{display:flex;justify-content:center;margin-bottom:44px}
.score-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:24px;padding:36px 56px;text-align:center}
.score-ring{width:140px;height:140px;margin:0 auto 18px;position:relative}
.score-ring-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column}
.score-num{font-family:'Playfair Display',serif;font-size:42px;font-weight:900;line-height:1;background:linear-gradient(135deg,#FF3CAC,#784BA0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.score-max{font-family:'DM Mono',monospace;font-size:11px;color:rgba(255,255,255,0.35)}
.score-title{font-size:14px;font-weight:600;margin-bottom:4px}
.score-grade{font-family:'DM Mono',monospace;font-size:12px;color:var(--mint);letter-spacing:2px;text-transform:uppercase}
.result-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:32px}
.result-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:20px;padding:26px;animation:fadeUp 0.5s ease forwards;opacity:0}
.result-card.full{grid-column:1/-1}
.result-card.accent{border-color:rgba(255,60,172,0.3);background:rgba(255,60,172,0.04)}
.card-eye{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.card-eye::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--pink);flex-shrink:0}
.card-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;font-style:italic;margin-bottom:8px;line-height:1.2}
.card-title.grad{background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.card-body{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.7}
.tag-cloud{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.tag{padding:5px 13px;border-radius:100px;font-size:11px;font-family:'DM Mono',monospace}
.tp{background:rgba(255,60,172,0.15);color:#FF7CD4;border:1px solid rgba(255,60,172,0.2)}
.tb{background:rgba(43,134,197,0.15);color:#6BB8E8;border:1px solid rgba(43,134,197,0.2)}
.tv{background:rgba(120,75,160,0.2);color:#B48FD4;border:1px solid rgba(120,75,160,0.3)}
.tm{background:rgba(0,245,212,0.1);color:var(--mint);border:1px solid rgba(0,245,212,0.2)}
.palette-row{display:flex;gap:8px;margin-top:14px}
.palette-swatch{flex:1;height:52px;border-radius:10px;display:flex;align-items:flex-end;padding:5px 8px;font-size:9px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.7)}
.vibe-bars{margin-top:14px;display:flex;flex-direction:column;gap:12px}
.vibe-bar-row{display:flex;align-items:center;gap:10px}
.vibe-bar-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;color:rgba(255,255,255,0.45);width:80px;text-align:right;flex-shrink:0}
.vibe-bar-track{flex:1;height:5px;background:rgba(255,255,255,0.07);border-radius:3px;overflow:hidden}
.vibe-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#FF3CAC,#784BA0);width:0;transition:width 1.2s cubic-bezier(0.25,1,0.5,1)}
.vibe-bar-val{font-family:'DM Mono',monospace;font-size:10px;color:rgba(255,255,255,0.3);width:28px;flex-shrink:0}
.tips-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.tip-item{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(255,255,255,0.6);line-height:1.5}
.tip-num{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,rgba(255,60,172,0.3),rgba(43,134,197,0.3));font-size:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'DM Mono',monospace;color:var(--cream);margin-top:1px}
.inspo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.inspo-pin{border-radius:14px;overflow:hidden;aspect-ratio:3/4;cursor:pointer;transition:transform 0.2s}
.inspo-pin:hover{transform:scale(1.03)}
.inspo-pin-bg{width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:12px}
.inspo-title{font-size:12px;font-weight:700;margin-bottom:2px}
.inspo-desc{font-family:'DM Mono',monospace;font-size:9px;color:rgba(255,255,255,0.6);letter-spacing:0.5px}
.reset-btn{display:block;margin:0 auto 80px;padding:13px 36px;border:1.5px solid rgba(255,255,255,0.2);border-radius:100px;background:transparent;color:rgba(255,255,255,0.55);font-family:'Syne',sans-serif;font-size:14px;cursor:pointer;transition:all 0.2s}
.reset-btn:hover{border-color:rgba(255,255,255,0.4);color:white}

/* TOOLS SECTION */
.tools-section{padding-bottom:80px}
.quiz-teaser{border-radius:26px;overflow:hidden;cursor:pointer;transition:transform 0.25s;margin-bottom:20px}
.quiz-teaser:hover{transform:translateY(-3px)}
.quiz-teaser-inner{background:linear-gradient(135deg,#1a0533 0%,#3d1060 45%,#6b1a5a 100%);padding:40px 36px;display:flex;align-items:center;justify-content:space-between;gap:28px;position:relative;overflow:hidden}
.quiz-teaser-inner::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,60,172,0.15)}
.quiz-teaser-left{position:relative;z-index:1}
.quiz-teaser-badge{display:inline-block;padding:4px 13px;border-radius:100px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.8);margin-bottom:12px}
.quiz-teaser-title{font-family:'Playfair Display',serif;font-size:clamp(22px,4vw,34px);font-weight:900;font-style:italic;line-height:1.05;margin-bottom:8px}
.quiz-teaser-sub{font-size:14px;color:rgba(255,255,255,0.55);margin-bottom:14px}
.quiz-teaser-chips{display:flex;flex-wrap:wrap;gap:6px}
.qc{padding:4px 12px;border-radius:100px;background:rgba(255,255,255,0.1);font-size:11px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.65)}
.quiz-teaser-cta{position:relative;z-index:1;flex-shrink:0;padding:14px 28px;background:white;border-radius:100px;font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:#1A1A2E;white-space:nowrap;transition:all 0.2s;border:none;cursor:pointer}
.quiz-teaser-cta:hover{background:var(--cream);transform:scale(1.03)}
.tools-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.tool-card{border-radius:24px;overflow:hidden;cursor:pointer;transition:transform 0.22s;padding:30px 24px 26px;display:flex;flex-direction:column}
.tool-card:hover{transform:translateY(-4px)}
.tc-glow{background:linear-gradient(145deg,#0f0a1a,#2a0d4a,#1a1040)}
.tc-color{background:linear-gradient(145deg,#0a1520,#0d3040,#12203a)}
.tc-hair{background:linear-gradient(145deg,#1a0a10,#3d1030,#250d3a)}
.tc-room{background:linear-gradient(145deg,#0a120a,#162814,#0f1e1a)}
.tool-badge{display:inline-block;padding:4px 12px;border-radius:100px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:16px;align-self:flex-start}
.tool-emoji{font-size:36px;margin-bottom:12px}
.tool-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:900;font-style:italic;line-height:1.05;letter-spacing:-0.5px;margin-bottom:10px}
.tool-desc{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.6;margin-bottom:18px;flex:1}
.tool-cta{padding:11px 20px;border-radius:100px;border:1.5px solid rgba(255,255,255,0.25);background:transparent;color:white;font-family:'Syne',sans-serif;font-size:13px;font-weight:600;cursor:pointer;align-self:flex-start;transition:all 0.2s}
.tool-card:hover .tool-cta{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.5)}

/* VIRAL TEASER */
.viral-teaser{border-radius:26px;overflow:hidden;cursor:pointer;transition:transform 0.25s}
.viral-teaser:hover{transform:translateY(-3px)}
.vt-left,.vt-mini{position:relative;z-index:1}
.viral-teaser{background:linear-gradient(135deg,#0d0018,#1e0038,#000d1a);padding:44px 36px 0;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;position:relative;overflow:hidden}
.viral-teaser::before{content:'';position:absolute;top:-60px;right:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,60,172,0.18) 0%,transparent 70%);pointer-events:none}
.vt-eyebrow{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:12px}
.vt-title{font-family:'Playfair Display',serif;font-size:clamp(24px,4vw,38px);font-weight:900;line-height:1;letter-spacing:-1px;margin-bottom:12px}
.vt-title em{font-style:italic;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.vt-sub{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.65;margin-bottom:14px;max-width:380px}
.vt-example{font-family:'Playfair Display',serif;font-style:italic;font-size:14px;color:rgba(255,255,255,0.4)}
.vt-mini{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:18px;padding:16px;width:190px;flex-shrink:0;box-shadow:0 20px 50px rgba(0,0,0,0.5)}
.vtm-name{font-family:'Playfair Display',serif;font-size:15px;font-style:italic;font-weight:700;margin-bottom:4px}
.vtm-score{font-family:'Playfair Display',serif;font-size:30px;font-weight:900;font-style:italic;background:linear-gradient(135deg,#FF3CAC,#784BA0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:14px}
.vtm-bar-row{display:flex;align-items:center;gap:7px;margin-bottom:7px;font-family:'DM Mono',monospace;font-size:8px;color:rgba(255,255,255,0.4);letter-spacing:1px}
.vtm-bar{height:4px;border-radius:2px;flex-shrink:0}
.vtm-footer{font-family:'DM Mono',monospace;font-size:8px;color:rgba(255,255,255,0.2);letter-spacing:1px;border-top:1px solid rgba(255,255,255,0.08);padding-top:10px;margin-top:12px}
.vt-btn{grid-column:1/-1;display:block;width:calc(100% + 72px);margin:24px -36px 0;padding:18px;border:none;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);color:white;font-family:'Syne',sans-serif;font-size:16px;font-weight:700;cursor:pointer;letter-spacing:0.5px}

/* PANEL */
.panel-overlay{position:fixed;inset:0;z-index:200;background:var(--charcoal);overflow-y:auto;animation:panelIn 0.4s cubic-bezier(0.25,1,0.5,1)}
.panel-nav{position:sticky;top:0;z-index:10;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,0.06);background:rgba(26,26,46,0.9)}
.panel-logo{font-family:'Playfair Display',serif;font-size:22px;font-weight:900;font-style:italic;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.panel-close{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.08);border:none;color:rgba(255,255,255,0.7);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.panel-close:hover{background:rgba(255,255,255,0.15);color:white}
.panel-body{max-width:660px;margin:0 auto;padding:0 20px 80px}

/* PANEL INNER SHARED */
.fp-hero{padding:50px 0 36px;text-align:center}
.fp-eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:4px;text-transform:uppercase;margin-bottom:14px}
.fp-title{font-family:'Playfair Display',serif;font-size:clamp(36px,9vw,58px);font-weight:900;line-height:0.93;letter-spacing:-2px;margin-bottom:16px}
.fp-title em{font-style:italic;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fp-sub{font-size:15px;color:rgba(255,255,255,0.5);line-height:1.7;max-width:460px;margin:0 auto 36px}
.sec-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.sec-label::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--pink);flex-shrink:0}
.fp-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.fp-chip{padding:7px 15px;border-radius:100px;cursor:pointer;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);font-size:12px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.55);transition:all 0.18s;user-select:none}
.fp-chip:hover{border-color:rgba(255,60,172,0.4);color:rgba(255,255,255,0.9)}
.fp-chip.on{border-color:var(--pink);background:rgba(255,60,172,0.12);color:var(--cream)}
.fp-textarea{width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:14px;padding:13px 16px;color:var(--cream);font-family:'Syne',sans-serif;font-size:14px;line-height:1.6;resize:none;transition:border-color 0.2s;outline:none}
.fp-textarea:focus{border-color:rgba(255,60,172,0.4)}
.fp-textarea::placeholder{color:rgba(255,255,255,0.22)}
.fp-input{width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:13px;padding:13px 16px;color:var(--cream);font-family:'Syne',sans-serif;font-size:15px;outline:none;transition:border-color 0.2s;margin-bottom:20px}
.fp-input:focus{border-color:rgba(255,60,172,0.4)}
.fp-input::placeholder{color:rgba(255,255,255,0.22)}
.fp-btn{width:100%;padding:17px;border:none;border-radius:15px;color:white;font-family:'Syne',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:all 0.2s;margin-bottom:36px}
.fp-btn:hover{transform:translateY(-2px);box-shadow:0 18px 48px rgba(255,60,172,0.3)}
.fp-btn:disabled{opacity:0.45;cursor:not-allowed;transform:none;box-shadow:none}
.fp-primary{background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5)}
.fp-mint{background:linear-gradient(135deg,#00F5D4,#2B86C5)}
.fp-violet{background:linear-gradient(135deg,#FF3CAC,#784BA0)}
.fp-upload-zone{border:1.5px dashed rgba(255,255,255,0.18);border-radius:22px;padding:44px 24px;text-align:center;cursor:pointer;transition:all 0.3s;background:rgba(255,255,255,0.02);margin-bottom:20px}
.fp-upload-zone:hover,.fp-upload-zone.drag-over{border-color:var(--pink);background:rgba(255,60,172,0.04)}
.fp-upload-zone.mint:hover,.fp-upload-zone.mint.drag-over{border-color:var(--mint);background:rgba(0,245,212,0.04)}
.fp-preview{display:none;margin-bottom:20px}
.fp-preview img{width:100%;max-height:260px;object-fit:cover;border-radius:16px}
.fp-preview-change{margin-top:8px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;color:rgba(255,255,255,0.3);cursor:pointer;transition:color 0.2s}
.fp-preview-change:hover{color:var(--pink)}
.fp-loading{display:none;text-align:center;padding:70px 0}
.fp-loading.on{display:block}
.fp-load-orb{width:68px;height:68px;border-radius:50%;margin:0 auto 20px;animation:pulse 1.5s ease-in-out infinite}
.fp-load-title{font-size:20px;font-weight:700;margin-bottom:6px}
.fp-load-sub{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;color:rgba(255,255,255,0.35)}
.fp-load-dots{display:flex;justify-content:center;gap:8px;margin-top:22px}
.fp-ld{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.15)}
.fp-ld:nth-child(1){animation:dotPop 1.2s ease-in-out infinite 0s}
.fp-ld:nth-child(2){animation:dotPop 1.2s ease-in-out infinite 0.2s}
.fp-ld:nth-child(3){animation:dotPop 1.2s ease-in-out infinite 0.4s}
.fp-results{display:none}
.fp-results.on{display:block}
.fp-res-top{text-align:center;margin-bottom:32px}
.fp-res-eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:12px}
.fp-res-name{font-family:'Playfair Display',serif;font-size:clamp(38px,10vw,60px);font-weight:900;font-style:italic;line-height:0.93;letter-spacing:-2px;margin-bottom:10px}
.fp-res-tagline{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:3px;color:rgba(255,255,255,0.4)}
.info-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:18px;padding:20px;margin-bottom:14px}
.info-card-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.info-card-label::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--pink);flex-shrink:0}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.ul-plain{list-style:none;display:flex;flex-direction:column;gap:7px}
.ul-plain li{font-size:13px;color:rgba(255,255,255,0.62);display:flex;align-items:flex-start;gap:7px;line-height:1.5}
.ul-plain li::before{content:'✦';font-size:9px;color:var(--pink);margin-top:3px;flex-shrink:0}
.ul-plain.mint li::before{color:var(--mint)}
.fp-reset-btn{display:block;margin:0 auto;padding:12px 32px;border:1.5px solid rgba(255,255,255,0.18);border-radius:100px;background:transparent;color:rgba(255,255,255,0.5);font-family:'Syne',sans-serif;font-size:13px;cursor:pointer;transition:all 0.2s}
.fp-reset-btn:hover{border-color:rgba(255,255,255,0.35);color:white}
.share-strip{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.share-main{grid-column:1/-1;padding:15px;border-radius:13px;border:none;background:linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);color:white;font-family:'Syne',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all 0.2s}
.share-main:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,60,172,0.3)}
.share-sec{padding:13px;border-radius:13px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.7);font-family:'Syne',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s}
.share-sec:hover{background:rgba(255,255,255,0.1);color:white}

/* FOOTER */
footer{border-top:1px solid rgba(255,255,255,0.05);padding:32px 0;text-align:center;position:relative;z-index:2}
.footer-logo{font-family:'Playfair Display',serif;font-size:20px;font-style:italic;font-weight:900;background:linear-gradient(135deg,#FF3CAC,#784BA0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.footer-sub{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:rgba(255,255,255,0.2)}

/* TOAST */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);padding:11px 22px;background:rgba(0,245,212,0.15);border:1px solid rgba(0,245,212,0.3);border-radius:100px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--mint);z-index:9999;opacity:0;transition:all 0.3s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* SWATCH */
.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:10px;margin-bottom:14px}
.swatch{border-radius:12px;overflow:hidden}
.swatch-color{height:56px}
.swatch-info{padding:6px 8px;background:rgba(255,255,255,0.04)}
.swatch-name{font-size:10px;font-weight:700;color:rgba(255,255,255,0.8);margin-bottom:1px}
.swatch-hex{font-family:'DM Mono',monospace;font-size:9px;color:rgba(255,255,255,0.35)}

/* QUIZ specific */
.qp-progress-track{height:3px;background:rgba(255,255,255,0.08);border-radius:2px;overflow:hidden;margin-bottom:28px}
.qp-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#FF3CAC,#784BA0);transition:width 0.5s cubic-bezier(0.25,1,0.5,1)}
.qp-question-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:22px;padding:26px 22px}
.qp-q-num{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--pink);margin-bottom:12px}
.qp-q-emoji{font-size:32px;margin-bottom:12px;display:block}
.qp-q-text{font-family:'Playfair Display',serif;font-size:clamp(20px,5vw,26px);font-weight:700;line-height:1.2;margin-bottom:22px}
.qp-opts{display:grid;gap:8px}
.qp-opts.cols2{grid-template-columns:1fr 1fr}
.qp-opt{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:12px 14px;color:var(--cream);font-family:'Syne',sans-serif;font-size:13px;font-weight:500;line-height:1.4;cursor:pointer;text-align:left;transition:all 0.18s;position:relative;display:flex;align-items:flex-start;gap:8px}
.qp-opt-em{font-size:17px;flex-shrink:0;margin-top:1px}
.qp-opt-sub{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.5px;color:rgba(255,255,255,0.3);display:block;margin-top:2px}
.qp-opt:hover{border-color:rgba(255,60,172,0.4);background:rgba(255,60,172,0.07);transform:translateY(-1px)}
.qp-opt.sel{border-color:var(--pink);background:rgba(255,60,172,0.12)}
.qp-opt.sel::after{content:'✓';position:absolute;top:9px;right:10px;font-size:11px;color:var(--pink)}
.qp-next{width:100%;margin-top:13px;padding:14px;background:linear-gradient(135deg,#FF3CAC,#784BA0);border:none;border-radius:12px;color:white;font-family:'Syne',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all 0.2s;opacity:0.4;pointer-events:none}
.qp-next.ready{opacity:1;pointer-events:all}
.qp-next.ready:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(255,60,172,0.3)}

/* SHARE CARD */
.share-card{border-radius:24px;overflow:hidden;margin-bottom:22px}
.share-card-inner{padding:30px 26px}
.sc-badge{display:inline-block;padding:5px 13px;border-radius:100px;border:1px solid rgba(255,255,255,0.2);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:14px}
.sc-name{font-family:'Playfair Display',serif;font-size:clamp(32px,9vw,48px);font-weight:900;font-style:italic;line-height:0.95;letter-spacing:-1.5px;margin-bottom:10px}
.sc-desc{font-size:14px;line-height:1.7;color:rgba(255,255,255,0.8);margin-bottom:18px}
.sc-vibes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.sc-vibe{padding:5px 12px;border-radius:100px;font-size:11px;font-family:'DM Mono',monospace;background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.8);border:1px solid rgba(255,255,255,0.15)}
.sc-inspos{display:flex;gap:7px}
.sc-inspo{flex:1;padding:10px;background:rgba(0,0,0,0.25);border-radius:11px;font-size:11px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.55);text-align:center}
.sc-inspo strong{display:block;font-size:13px;font-family:'Syne',sans-serif;font-weight:700;color:rgba(255,255,255,0.95);margin-bottom:2px}
.sc-footer{margin-top:18px;padding-top:12px;border-top:1px solid rgba(255,255,255,0.12);display:flex;justify-content:space-between;align-items:center}
.sc-footer-logo{font-family:'Playfair Display',serif;font-size:15px;font-weight:900;font-style:italic;color:rgba(255,255,255,0.9)}
.sc-footer-url{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:rgba(255,255,255,0.25)}
.match-bars{display:flex;flex-direction:column;gap:9px}
.match-row{display:flex;align-items:center;gap:8px}
.match-name{font-family:'DM Mono',monospace;font-size:10px;width:90px;text-align:right;color:rgba(255,255,255,0.4);flex-shrink:0}
.match-track{flex:1;height:5px;background:rgba(255,255,255,0.07);border-radius:3px;overflow:hidden}
.match-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#FF3CAC,#784BA0);width:0;transition:width 1.2s cubic-bezier(0.25,1,0.5,1)}
.match-pct{font-family:'DM Mono',monospace;font-size:10px;color:rgba(255,255,255,0.3);width:28px;flex-shrink:0}

/* GLOW UP */
.gp-plan-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}
.gp-plan-btn{padding:16px 10px;border-radius:16px;cursor:pointer;text-align:center;border:1.5px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.03);transition:all 0.2s}
.gp-plan-btn:hover{border-color:rgba(255,60,172,0.4);background:rgba(255,60,172,0.05)}
.gp-plan-btn.on{border-color:var(--pink);background:rgba(255,60,172,0.1)}
.gp-plan-emoji{font-size:26px;margin-bottom:6px}
.gp-plan-name{font-weight:700;font-size:13px;margin-bottom:2px}
.gp-plan-desc{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.5px;color:rgba(255,255,255,0.35)}
.day-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:18px;overflow:hidden;margin-bottom:12px}
.day-header{padding:14px 20px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background 0.2s}
.day-header:hover{background:rgba(255,255,255,0.02)}
.day-num{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,rgba(255,60,172,0.3),rgba(43,134,197,0.3));display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:11px}
.day-name{font-weight:700;font-size:14px;flex:1}
.day-theme{font-family:'DM Mono',monospace;font-size:10px;color:var(--pink);letter-spacing:1px}
.day-chev{font-size:11px;color:rgba(255,255,255,0.3);transition:transform 0.2s}
.day-card.open .day-chev{transform:rotate(180deg)}
.day-body{display:none;padding:18px 20px}
.day-card.open .day-body{display:block}
.day-tasks{display:flex;flex-direction:column;gap:9px}
.day-task{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(255,255,255,0.65);line-height:1.5}
.day-task-icon{width:26px;height:26px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;background:rgba(255,255,255,0.06)}
.sec-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.conf-card{background:linear-gradient(135deg,rgba(255,60,172,0.1),rgba(43,134,197,0.08));border:1px solid rgba(255,60,172,0.2);border-radius:18px;padding:22px;margin-bottom:20px;text-align:center}
.conf-emoji{font-size:34px;margin-bottom:10px}
.conf-title{font-family:'Playfair Display',serif;font-size:20px;font-style:italic;font-weight:700;margin-bottom:6px}
.conf-body{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.65}

/* COLOR ANALYSIS */
.avoid-card{background:rgba(255,60,172,0.05);border:1px solid rgba(255,60,172,0.15);border-radius:16px;padding:18px;margin-bottom:14px}
.avoid-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,60,172,0.6);margin-bottom:10px}
.avoid-swatches{display:flex;flex-wrap:wrap;gap:8px}
.avoid-swatch{display:flex;align-items:center;gap:7px;padding:5px 11px;border-radius:100px;background:rgba(255,255,255,0.05);font-size:11px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.5)}
.avoid-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.makeup-card{background:rgba(0,245,212,0.06);border:1px solid rgba(0,245,212,0.15);border-radius:18px;padding:22px;margin-bottom:14px}
.makeup-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(0,245,212,0.7);margin-bottom:12px}
.makeup-row{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(255,255,255,0.65);line-height:1.5;margin-bottom:9px}
.makeup-icon{font-size:16px;flex-shrink:0;width:26px}

/* HAIR */
.hr-mode-row{display:flex;gap:10px;margin-bottom:22px}
.hr-mode-btn{flex:1;padding:13px;border-radius:13px;cursor:pointer;text-align:center;border:1.5px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.03);font-family:'Syne',sans-serif;font-size:13px;font-weight:600;color:rgba(255,255,255,0.5);transition:all 0.2s}
.hr-mode-btn.on{border-color:var(--pink);background:rgba(255,60,172,0.1);color:var(--cream)}
.color-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.color-chip{display:flex;align-items:center;gap:7px;padding:7px 13px;border-radius:100px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);font-size:11px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.7)}
.color-dot{width:13px;height:13px;border-radius:50%;flex-shrink:0}
.routine-steps{display:flex;flex-direction:column;gap:9px}
.routine-step{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(255,255,255,0.65);line-height:1.5}
.routine-step-num{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,rgba(255,60,172,0.3),rgba(120,75,160,0.3));display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:10px;flex-shrink:0;margin-top:1px}
.avoid-list{list-style:none;display:flex;flex-direction:column;gap:7px}
.avoid-list li{font-size:13px;color:rgba(255,255,255,0.6);display:flex;align-items:flex-start;gap:7px;line-height:1.5}
.avoid-list li::before{content:'✗';font-size:10px;color:rgba(255,60,172,0.6);margin-top:1px;flex-shrink:0}

/* ROOM */
.score-chips{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:28px}
.score-chip{padding:9px 20px;border-radius:100px;text-align:center;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1)}
.score-chip-num{font-family:'Playfair Display',serif;font-size:26px;font-weight:900;font-style:italic;background:linear-gradient(135deg,#00F5D4,#2B86C5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.score-chip-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:rgba(255,255,255,0.3);text-transform:uppercase}
.ra-chips-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.ra-chip{padding:7px 14px;border-radius:100px;cursor:pointer;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);font-size:12px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.55);transition:all 0.18s}
.ra-chip:hover{border-color:rgba(0,245,212,0.4);color:rgba(255,255,255,0.9)}
.ra-chip.on{border-color:var(--mint);background:rgba(0,245,212,0.1);color:var(--cream)}
.inspo-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:14px}
.inspo3-pin{border-radius:14px;overflow:hidden;aspect-ratio:3/4}
.inspo3-inner{width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:12px}
.inspo3-title{font-size:12px;font-weight:700;margin-bottom:2px}
.inspo3-sub{font-family:'DM Mono',monospace;font-size:9px;color:rgba(255,255,255,0.6);letter-spacing:0.5px}
.shop-items{display:flex;flex-direction:column;gap:9px}
.shop-item{display:flex;align-items:flex-start;gap:10px}
.shop-icon{font-size:18px;flex-shrink:0;width:28px}
.shop-text{font-size:13px;color:rgba(255,255,255,0.65);line-height:1.5}
.shop-text strong{display:block;font-size:14px;color:rgba(255,255,255,0.9);margin-bottom:1px}

/* VIRAL CARD */
.vc-sliders{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.vc-slider-row{display:flex;align-items:center;gap:10px}
.vc-aes-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.vc-aes-name{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.5px;width:105px;flex-shrink:0;color:rgba(255,255,255,0.7)}
.vc-aes-track{flex:1}
.vc-aes-track input[type=range]{width:100%}
.vc-aes-pct{font-family:'DM Mono',monospace;font-size:11px;font-weight:500;color:var(--cream);width:33px;text-align:right;flex-shrink:0}
.vc-style-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}
.vc-style-btn{border-radius:14px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all 0.2s;aspect-ratio:3/4}
.vc-style-btn.sel{border-color:var(--pink);transform:scale(1.03)}
.vc-style-preview{width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:11px}
.vc-sp-name{font-size:12px;font-weight:700;color:rgba(255,255,255,0.9)}
.vc-sp-sub{font-family:'DM Mono',monospace;font-size:8px;color:rgba(255,255,255,0.45);letter-spacing:1px}
.vc-badge-grid{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:24px}
.vc-badge-chip{padding:7px 15px;border-radius:100px;cursor:pointer;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);font-size:11px;font-family:'DM Mono',monospace;color:rgba(255,255,255,0.5);transition:all 0.18s;user-select:none}
.vc-badge-chip:hover{border-color:rgba(255,60,172,0.4)}
.vc-badge-chip.sel{border-color:var(--pink);background:rgba(255,60,172,0.12);color:var(--cream)}
.vc-score-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:22px}
.vc-score-field label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:rgba(255,255,255,0.3);display:block;margin-bottom:5px}
.vc-score-input{width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:9px;padding:10px;color:var(--cream);font-family:'DM Mono',monospace;font-size:15px;font-weight:500;outline:none;transition:border-color 0.2s;text-align:center}
.vc-score-input:focus{border-color:rgba(255,60,172,0.4)}
.vc-card{border-radius:24px;overflow:hidden;margin-bottom:22px;box-shadow:0 36px 72px rgba(0,0,0,0.6)}
.vc-card-inner{padding:32px 28px 26px}
.vc-card-hd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.vc-card-brand{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.4)}
.vc-card-date{font-family:'DM Mono',monospace;font-size:9px;color:rgba(255,255,255,0.25)}
.vc-card-aes{font-family:'Playfair Display',serif;font-size:clamp(32px,8vw,52px);font-weight:900;font-style:italic;line-height:0.9;letter-spacing:-2px;margin-bottom:7px}
.vc-card-tag{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;color:rgba(255,255,255,0.5);margin-bottom:24px}
.vc-scores-row{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.vc-orb{width:68px;height:68px;border-radius:50%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);display:flex;flex-direction:column;align-items:center;justify-content:center}
.vc-orb-num{font-family:'Playfair Display',serif;font-size:19px;font-weight:900;font-style:italic;line-height:1;background:linear-gradient(135deg,#FF3CAC,#784BA0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.vc-orb-label{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:1px;color:rgba(255,255,255,0.35);text-transform:uppercase;margin-top:1px}
.vc-dna-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:12px}
.vc-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.vc-bar-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.vc-bar-name{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.5px;color:rgba(255,255,255,0.55);width:85px;flex-shrink:0}
.vc-bar-track{flex:1;height:5px;background:rgba(255,255,255,0.08);border-radius:3px;overflow:hidden}
.vc-bar-fill{height:100%;border-radius:3px;width:0;transition:width 1.2s cubic-bezier(0.25,1,0.5,1)}
.vc-bar-pct{font-family:'DM Mono',monospace;font-size:9px;color:rgba(255,255,255,0.35);width:28px;text-align:right;flex-shrink:0}
.vc-badges{display:flex;flex-wrap:wrap;gap:6px;margin:18px 0}
.vc-badge{padding:5px 12px;border-radius:100px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.8)}
.vc-badge.hot{background:rgba(255,60,172,0.2);border-color:rgba(255,60,172,0.4);color:var(--pink)}
.vc-ba{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:14px;padding:14px;margin-bottom:18px}
.vc-ba-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:10px}
.vc-ba-row{display:flex;align-items:center;gap:8px}
.vc-ba-col{flex:1}
.vc-ba-period{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:rgba(255,255,255,0.25);margin-bottom:4px}
.vc-ba-val{font-family:'Playfair Display',serif;font-size:16px;font-style:italic;font-weight:700;color:rgba(255,255,255,0.85)}
.vc-ba-arrow{color:var(--mint);font-size:16px;padding-top:4px}
.vc-card-ft{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid rgba(255,255,255,0.1);margin-top:18px}
.vc-ft-logo{font-family:'Playfair Display',serif;font-size:14px;font-weight:900;font-style:italic;color:rgba(255,255,255,0.8)}
.vc-ft-url{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:rgba(255,255,255,0.2)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:scale(0.8)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:0.9}50%{transform:scale(1.05);opacity:1}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
@keyframes panelIn{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
@keyframes dotPop{0%,100%{background:rgba(255,255,255,0.15);transform:scale(1)}40%{background:var(--pink);transform:scale(1.4)}}

/* MOBILE */
@media(max-width:680px){
  nav{padding:14px 18px}
  .nav-link{display:none}
  .result-grid,.info-grid,.sec-grid,.gp-plan-row,.vc-score-row{grid-template-columns:1fr}
  .tools-row{grid-template-columns:1fr}
  .quiz-teaser-inner{flex-direction:column;padding:28px 22px;gap:20px}
  .quiz-teaser-cta{width:100%;text-align:center}
  .viral-teaser{grid-template-columns:1fr;padding:32px 22px 0}
  .vt-mini{width:100%}
  .vt-btn{width:calc(100% + 44px);margin-left:-22px;margin-right:-22px}
  .qp-opts.cols2{grid-template-columns:1fr}
  .vc-style-grid{grid-template-columns:1fr 1fr}
  .inspo-grid3{grid-template-columns:1fr 1fr}
}

/* ── SOCIAL PROOF BAR ── */
.social-proof-bar{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:100px;padding:10px 24px;flex-wrap:wrap;gap:4px;animation:fadeUp 0.4s ease forwards;opacity:0}
.sp-item{display:flex;align-items:center;gap:6px;padding:0 12px}
.sp-num{font-family:'Playfair Display',serif;font-size:16px;font-weight:900;font-style:italic;background:linear-gradient(135deg,#FF3CAC,#784BA0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sp-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;color:rgba(255,255,255,0.45);text-transform:uppercase}
.sp-trending{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:1px;color:rgba(255,255,255,0.7)}
.sp-stars{color:#FFD700;font-size:13px;letter-spacing:2px}
.sp-divider{width:1px;height:20px;background:rgba(255,255,255,0.1);flex-shrink:0}

/* ── CATEGORY LABEL ── */
.category-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.35);text-align:center;margin:20px 0 10px}

/* ── UPLOAD PULSE RING ── */
.upload-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;border:2px solid rgba(255,60,172,0.3);animation:uploadPulse 2s ease-in-out infinite;pointer-events:none}
.upload-zone{position:relative;overflow:hidden}
@keyframes uploadPulse{0%{transform:translate(-50%,-50%) scale(0.8);opacity:0.8}100%{transform:translate(-50%,-50%) scale(2);opacity:0}}

/* ── COUNTER ANIMATION ── */
@keyframes countUp{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ── MOBILE social proof ── */
@media(max-width:660px){
  .social-proof-bar{padding:8px 14px;gap:2px}
  .sp-item{padding:0 8px}
  .sp-divider{height:14px}
  .sp-num{font-size:14px}
  .sp-label{font-size:9px}
}

/* ═══════════════════════════════════════════════
   HERO SPLIT LAYOUT + VIRAL CARD PREVIEW
   ═══════════════════════════════════════════════ */

/* Split container */
.hero-split{display:grid;grid-template-columns:1fr 420px;gap:56px;align-items:start;padding:120px 0 60px;text-align:left}
.hero-left{display:flex;flex-direction:column}
.hero-right{position:sticky;top:100px;display:flex;flex-direction:column;align-items:center;gap:16px}

/* Override hero center alignment for split layout */
.hero-split .hero-eyebrow{text-align:left;margin-bottom:18px}
.hero-split .hero-title{font-size:clamp(42px,5.5vw,72px);letter-spacing:-2.5px;text-align:left;margin-bottom:20px}
.hero-split .hero-sub{text-align:left;margin:0 0 28px;max-width:100%}
.hero-split .social-proof-bar{justify-content:flex-start}
.hero-split .upload-zone{text-align:center}
.hero-split .category-label{text-align:left}
.hero-split .category-strip{justify-content:flex-start}

/* Card showcase label */
.hrc-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.35);text-align:center;margin-bottom:14px}

/* Card wrap — clips the carousel */
.hero-card-wrap{width:100%;max-width:320px;position:relative;height:420px}

/* Individual hero cards */
.hero-card{position:absolute;inset:0;opacity:0;transform:translateY(18px) scale(0.97);transition:opacity 0.6s cubic-bezier(0.25,1,0.5,1),transform 0.6s cubic-bezier(0.25,1,0.5,1);pointer-events:none;border-radius:22px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.08)}
.hero-card.hc-active{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.hero-card.hc-exit{opacity:0;transform:translateY(-14px) scale(0.97)}

/* Card inner content */
.hc-inner{padding:22px 20px 18px;height:100%;display:flex;flex-direction:column;gap:0}
.hc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.hc-brand{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.38)}
.hc-date{font-family:'DM Mono',monospace;font-size:7px;color:rgba(255,255,255,0.22)}
.hc-aes{font-family:'Playfair Display',serif;font-size:clamp(26px,5vw,34px);font-weight:900;font-style:italic;line-height:0.92;letter-spacing:-1px;margin-bottom:5px}
.hc-tag{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:rgba(255,255,255,0.42);margin-bottom:16px}
.hc-scores{display:flex;align-items:center;gap:9px;margin-bottom:18px}
.hc-orb{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}
.hc-grade{font-family:'Playfair Display',serif;font-size:15px;font-weight:900;font-style:italic;line-height:1;background:linear-gradient(135deg,#FF3CAC,#784BA0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hc-olbl{font-family:'DM Mono',monospace;font-size:6px;letter-spacing:1px;color:rgba(255,255,255,0.3);text-transform:uppercase;margin-top:1px}
.hc-name-wrap{display:flex;flex-direction:column;justify-content:center;gap:3px;margin-left:4px}
.hc-uname{font-family:'Playfair Display',serif;font-size:12px;font-style:italic;font-weight:700;color:rgba(255,255,255,0.88)}
.hc-sub{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:2px;color:rgba(255,255,255,0.28)}
.hc-dna{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.28);margin-bottom:9px}
.hc-bar-row{display:flex;align-items:center;gap:6px;margin-bottom:7px}
.hc-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.hc-bname{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:0.5px;color:rgba(255,255,255,0.45);width:62px;flex-shrink:0}
.hc-btrack{flex:1;height:4px;background:rgba(255,255,255,0.07);border-radius:2px;overflow:hidden}
.hc-bfill{height:100%;border-radius:2px}
.hc-bpct{font-family:'DM Mono',monospace;font-size:7px;color:rgba(255,255,255,0.3);width:22px;text-align:right;flex-shrink:0}
.hc-badges{display:flex;flex-wrap:wrap;gap:5px;margin:12px 0 0}
.hc-badge{padding:3px 9px;border-radius:100px;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:1px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.75)}
.hc-badge.hot{background:rgba(255,60,172,0.18);border-color:rgba(255,60,172,0.38);color:#FF3CAC}
.hc-footer{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid rgba(255,255,255,0.08);margin-top:auto}
.hc-flogo{font-family:'Playfair Display',serif;font-size:12px;font-weight:900;font-style:italic;color:rgba(255,255,255,0.78)}
.hc-furl{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:2px;color:rgba(255,255,255,0.2)}

/* Dot indicators */
.hc-dots{display:flex;gap:7px;justify-content:center}
.hc-dot-ind{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.2);cursor:pointer;transition:all 0.3s}
.hc-dot-ind.active{background:var(--pink);width:20px;border-radius:3px}

/* CTA below card */
.hrc-cta{padding:11px 26px;background:linear-gradient(135deg,#FF3CAC,#784BA0);border:none;border-radius:100px;color:white;font-family:'Syne',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s;letter-spacing:0.3px}
.hrc-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,60,172,0.4)}

/* Floating glow behind card */
.hero-right::before{content:'';position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,60,172,0.12) 0%,transparent 70%);pointer-events:none;z-index:0}
.hero-card-wrap,.hrc-label,.hc-dots,.hrc-cta{position:relative;z-index:1}

/* ── MOBILE: stack vertically ── */
@media(max-width:900px){
  .hero-split{grid-template-columns:1fr;gap:40px;padding:110px 0 40px;text-align:center}
  .hero-split .hero-eyebrow,.hero-split .hero-title,.hero-split .hero-sub,.hero-split .category-label{text-align:center}
  .hero-split .category-strip,.hero-split .social-proof-bar{justify-content:center}
  .hero-right{position:static;order:-1}
  .hero-card-wrap{max-width:300px;height:380px}
  .hc-aes{font-size:28px}
}
@media(max-width:660px){
  .hero-card-wrap{max-width:280px;height:360px}
}

/* ── VOYA LOGO SVG ─────────────────────────────────── */
.nav-logo-link{display:flex;align-items:center;text-decoration:none;line-height:0;flex-shrink:0}
.nav-logo-link svg{width:110px;height:27px;transition:opacity 0.2s}
.nav-logo-link:hover svg{opacity:0.8}
.footer-logo svg{width:130px;height:36px;opacity:0.85}
.footer-logo svg:hover{opacity:1}
/* Mobile: slightly smaller */
@media(max-width:660px){
  .nav-logo-link svg{width:90px;height:22px}
  .footer-logo svg{width:110px;height:30px}
}
