/* MysticFate — Ultra Premium Design System */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600;700&display=swap');
:root{
  --bg:#07091a;--bg2:#0d1029;--bg3:#131640;
  --card:rgba(255,255,255,.03);--card2:rgba(255,255,255,.05);--card-b:rgba(255,255,255,.06);
  --p1:#8b5cf6;--p2:#a78bfa;--p3:#c4b5fd;--p4:#6d28d9;
  --c1:#06b6d4;--c2:#22d3ee;--c3:#67e8f9;
  --r1:#f43f5e;--r2:#fb7185;
  --g1:#10b981;--g2:#34d399;
  --o1:#f59e0b;--o2:#fbbf24;
  --w:#e8e6f0;--w2:#b8b5cb;--w3:#7c789a;--w4:#4a4668;
  --gd1:linear-gradient(135deg,#8b5cf6,#6366f1,#4f46e5);
  --gd2:linear-gradient(135deg,#06b6d4,#8b5cf6);
  --gd3:linear-gradient(135deg,#f43f5e,#8b5cf6);
  --gd4:linear-gradient(135deg,#8b5cf6 0%,#06b6d4 50%,#10b981 100%);
  --r:20px;--rs:14px;
  --shadow:0 8px 32px rgba(0,0,0,.4);
  --glow:0 0 40px rgba(139,92,246,.15);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--w);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;letter-spacing:.01em}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% -10%,rgba(139,92,246,.12),transparent 55%),radial-gradient(ellipse at 80% 110%,rgba(6,182,212,.08),transparent 50%),radial-gradient(circle at 50% 50%,rgba(139,92,246,.03),transparent 70%);pointer-events:none;z-index:0}
.serif{font-family:'Playfair Display',serif}

#app{max-width:430px;margin:0 auto;min-height:100vh;position:relative;z-index:1}

/* Header */
.hd{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:rgba(7,9,26,.88);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(255,255,255,.04)}
.hd-logo{display:flex;align-items:center;gap:10px}
.hd-logo-dot{width:8px;height:8px;border-radius:50%;background:var(--gd2);box-shadow:0 0 12px rgba(6,182,212,.5);animation:glow-pulse 3s ease-in-out infinite}
.hd-logo-text{font-family:'Playfair Display',serif;font-weight:700;font-size:1.05rem;letter-spacing:4px;background:linear-gradient(135deg,#c4b5fd,#a78bfa,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hd-acts{display:flex;align-items:center;gap:8px}
.hd-btn{width:36px;height:36px;border-radius:50%;background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--w3);font-size:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}
.hd-btn:hover{border-color:var(--p1);color:var(--p2);box-shadow:0 0 20px rgba(139,92,246,.2);transform:scale(1.05)}
.hd-btn img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.lang-btn{font-size:.55rem;font-weight:700;letter-spacing:1.5px;padding:7px 14px;border-radius:20px;background:rgba(139,92,246,.06);border:1px solid rgba(139,92,246,.12);cursor:pointer;color:var(--w3);transition:all .3s}
.lang-btn:hover{border-color:var(--p2);color:var(--p2)}

/* Content */
.ct{padding:0 16px 110px}
.sec{margin-top:20px}
.sec-t{font-size:.55rem;font-weight:700;color:var(--w4);letter-spacing:4px;text-transform:uppercase;margin-bottom:14px;padding-left:2px}

/* Cards */
.cd{background:var(--card);border:1px solid var(--card-b);border-radius:var(--r);padding:22px;margin-bottom:14px;backdrop-filter:blur(12px);transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.cd::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)}
.cd:hover{background:var(--card2);border-color:rgba(139,92,246,.12);box-shadow:var(--glow)}

/* Score Hero */
.hero{text-align:center;padding:32px 20px 28px}
.score-orb{width:160px;height:160px;border-radius:50%;margin:0 auto;position:relative;display:flex;align-items:center;justify-content:center}
.score-orb::before{content:'';position:absolute;inset:-3px;border-radius:50%;background:conic-gradient(from 180deg,var(--p1) 0deg,var(--c1) calc(var(--s)*3.6deg),transparent calc(var(--s)*3.6deg));opacity:.7;animation:orb-spin 20s linear infinite}
.score-orb::after{content:'';position:absolute;inset:5px;border-radius:50%;background:radial-gradient(circle at 40% 35%,var(--bg3),var(--bg))}
.score-core{position:relative;z-index:2;text-align:center}
.score-val{font-family:'Playfair Display',serif;font-size:3rem;font-weight:800;background:linear-gradient(180deg,#fff,var(--p3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.score-lbl{font-size:.45rem;font-weight:700;color:var(--w4);letter-spacing:5px;margin-top:6px}
.hero-sign{margin-top:18px;font-size:.8rem;color:var(--w2);letter-spacing:1px;display:flex;align-items:center;justify-content:center;gap:6px}
.hero-sign .emoji{font-size:1.1rem}
.hero-oracle{font-size:.82rem;color:var(--w3);line-height:1.9;text-align:center;margin:18px 0 0;font-weight:300}

/* Dimension Scores */
.dims{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:20px}
.dim{text-align:center;padding:16px 6px;background:rgba(139,92,246,.04);border:1px solid rgba(139,92,246,.08);border-radius:var(--rs);transition:all .3s;position:relative;overflow:hidden}
.dim:hover{border-color:rgba(139,92,246,.2);transform:translateY(-2px);box-shadow:0 6px 20px rgba(139,92,246,.1)}
.dim-v{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;background:var(--gd2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.dim-l{font-size:.45rem;font-weight:700;color:var(--w4);letter-spacing:2.5px;margin-top:5px}

/* Service Grid */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.svc{text-align:center;padding:20px 8px 16px;background:var(--card);border:1px solid var(--card-b);border-radius:var(--rs);cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative}
.svc:hover{transform:translateY(-4px);border-color:rgba(139,92,246,.2);box-shadow:0 12px 32px rgba(139,92,246,.12)}
.svc-ico{width:44px;height:44px;border-radius:14px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;position:relative}
.svc-ico::before{content:'';position:absolute;inset:0;border-radius:14px;opacity:.12}
.svc:nth-child(1) .svc-ico::before{background:var(--gd1)}.svc:nth-child(2) .svc-ico::before{background:linear-gradient(135deg,#06b6d4,#0891b2)}.svc:nth-child(3) .svc-ico::before{background:linear-gradient(135deg,#f59e0b,#d97706)}.svc:nth-child(4) .svc-ico::before{background:var(--gd3)}.svc:nth-child(5) .svc-ico::before{background:linear-gradient(135deg,#10b981,#059669)}.svc:nth-child(6) .svc-ico::before{background:linear-gradient(135deg,#f43f5e,#e11d48)}.svc:nth-child(7) .svc-ico::before{background:linear-gradient(135deg,#ec4899,#db2777)}.svc:nth-child(8) .svc-ico::before{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}
.svc-name{font-size:.6rem;color:var(--w3);font-weight:600;letter-spacing:1px}

/* Bottom Nav */
.bnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;display:flex;background:rgba(7,9,26,.94);backdrop-filter:blur(30px);border-top:1px solid rgba(255,255,255,.04);padding:6px 0 env(safe-area-inset-bottom,8px);z-index:50}
.bnav-i{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 0 6px;cursor:pointer;color:var(--w4);transition:all .3s;position:relative;font-size:.5rem}
.bnav-i.on{color:var(--p2)}
.bnav-i.on::before{content:'';position:absolute;top:-1px;left:25%;right:25%;height:2px;background:var(--gd1);border-radius:2px}
.bnav-i i{font-size:1.15rem;transition:transform .25s}
.bnav-i.on i{transform:scale(1.15)}
.bnav-i span{font-weight:700;letter-spacing:1.5px}

/* Buttons */
.btn{padding:14px 30px;border-radius:30px;border:none;font-family:'DM Sans',sans-serif;font-weight:700;font-size:.82rem;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.5px}
.btn-p{background:var(--gd1);color:#fff;position:relative;overflow:hidden}
.btn-p::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .3s}
.btn-p:hover::before{opacity:1}
.btn-p:hover{box-shadow:0 8px 30px rgba(139,92,246,.35);transform:translateY(-2px)}
.btn-p:disabled{opacity:.35;cursor:default;transform:none;box-shadow:none}
.btn-o{background:transparent;border:1px solid rgba(139,92,246,.15);color:var(--w3)}
.btn-o:hover{border-color:var(--p2);color:var(--p2)}
.btn-w{width:100%}

/* Social Buttons */
.soc{width:100%;padding:14px 20px;border-radius:16px;border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-size:.82rem;font-weight:600;margin-bottom:10px;transition:all .3s;font-family:'DM Sans',sans-serif}
.soc.gg{background:#fff;color:#1a1a1a;border-color:#e5e5e5}
.soc.gg:hover{box-shadow:0 6px 20px rgba(0,0,0,.1);transform:translateY(-1px)}
.soc.gh{background:#161b22;color:#e6edf3;border-color:#30363d}
.soc.gh:hover{background:#1f2937;box-shadow:0 6px 20px rgba(0,0,0,.2);transform:translateY(-1px)}
.soc.gs{background:transparent;color:var(--w4);border-color:rgba(255,255,255,.06)}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(7,9,26,.75);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal{background:linear-gradient(160deg,#12143a,#0d1029);border:1px solid rgba(139,92,246,.1);border-radius:24px;padding:32px 26px;width:100%;max-width:380px;box-shadow:0 32px 64px rgba(0,0,0,.4),0 0 60px rgba(139,92,246,.08);position:relative;overflow:hidden}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.15),transparent)}
.modal-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.modal-tt{font-family:'Playfair Display',serif;font-weight:700;font-size:1.1rem;letter-spacing:2px;background:var(--gd2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.modal-x{cursor:pointer;color:var(--w4);font-size:1rem;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;background:rgba(255,255,255,.03)}
.modal-x:hover{background:rgba(255,255,255,.08);color:var(--w)}

/* Input */
.ig{margin-bottom:18px}
.ig-l{font-size:.5rem;color:var(--w4);letter-spacing:3px;font-weight:700;margin-bottom:8px;display:block}
.ig-f{width:100%;padding:13px 16px;background:rgba(139,92,246,.04);border:1px solid rgba(139,92,246,.1);border-radius:var(--rs);color:var(--w);font-size:.85rem;font-family:'DM Sans',sans-serif;outline:none;transition:all .3s;letter-spacing:.02em}
.ig-f:focus{border-color:var(--p1);box-shadow:0 0 0 3px rgba(139,92,246,.12)}
select.ig-f{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%237c789a' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}

/* Menu */
.menu{background:var(--card);border:1px solid var(--card-b);border-radius:var(--r);overflow:hidden;backdrop-filter:blur(12px)}
.mi{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .25s}
.mi:last-child{border-bottom:none}
.mi:hover{background:var(--card2)}
.mi-l{display:flex;align-items:center;gap:14px}
.mi-ico{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:.75rem}
.mi-ico.purple{background:rgba(139,92,246,.1);color:var(--p2)}
.mi-ico.cyan{background:rgba(6,182,212,.1);color:var(--c2)}
.mi-ico.red{background:rgba(244,63,94,.1);color:var(--r2)}
.mi-t{font-size:.82rem;font-weight:500;letter-spacing:.02em}
.mi-a{color:var(--w4);font-size:.55rem}

/* Sub-view */
.sv{position:fixed;inset:0;z-index:60;background:var(--bg);overflow-y:auto}
.sv-hd{display:flex;align-items:center;gap:14px;padding:16px 20px;background:rgba(7,9,26,.88);backdrop-filter:blur(30px);border-bottom:1px solid rgba(255,255,255,.04);position:sticky;top:0;z-index:10}
.sv-back{cursor:pointer;color:var(--w3);font-size:.9rem;padding:6px;transition:color .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.03)}
.sv-back:hover{color:var(--p2);background:rgba(139,92,246,.08)}
.sv-tt{font-family:'Playfair Display',serif;font-weight:600;font-size:.95rem;letter-spacing:3px;background:var(--gd2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sv-ct{padding:20px 16px 40px}

/* Result */
.res{background:linear-gradient(160deg,rgba(139,92,246,.08),rgba(6,182,212,.04));border:1px solid rgba(139,92,246,.15);border-radius:var(--r);padding:32px 24px;text-align:center;position:relative;overflow:hidden}
.res::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(139,92,246,.03),transparent 70%);animation:res-glow 6s ease-in-out infinite}
.res-emoji{font-size:3.5rem;margin-bottom:14px}
.res-tt{font-family:'Playfair Display',serif;font-weight:700;font-size:1.1rem;letter-spacing:2px;background:var(--gd2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.res-txt{font-size:.82rem;color:var(--w3);line-height:1.9;margin-top:14px;font-weight:300}

/* Profile */
.prof{display:flex;align-items:center;gap:18px;padding:22px}
.avatar{width:60px;height:60px;border-radius:50%;background:var(--gd1);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.3rem;color:#fff;font-weight:700;overflow:hidden;box-shadow:0 6px 20px rgba(139,92,246,.25);position:relative}
.avatar::before{content:'';position:absolute;inset:-2px;border-radius:50%;background:var(--gd4);z-index:-1;animation:avatar-ring 4s linear infinite}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.prof-name{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:600;letter-spacing:.5px}
.prof-sub{font-size:.6rem;color:var(--w4);margin-top:4px;letter-spacing:2px;font-weight:600}

/* Pillars */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.pil{text-align:center;padding:14px 8px;background:rgba(139,92,246,.04);border:1px solid rgba(139,92,246,.08);border-radius:var(--rs)}
.pil-l{font-size:.45rem;color:var(--w4);letter-spacing:2px;font-weight:700;margin-bottom:8px}
.pil-c{font-size:1.1rem;font-weight:700;color:var(--p3);line-height:1.4}

/* Onboarding */
.ob{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;position:relative}
.ob::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 20%,rgba(139,92,246,.15),transparent 60%),radial-gradient(ellipse at 30% 80%,rgba(6,182,212,.06),transparent 50%);pointer-events:none}
.ob-logo{font-family:'Playfair Display',serif;font-weight:800;font-size:2.4rem;letter-spacing:8px;background:linear-gradient(180deg,#e4e2f0,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1}
.ob-sub{font-size:.65rem;color:var(--w4);letter-spacing:6px;margin:10px 0 36px;font-weight:600;position:relative;z-index:1}

/* Misc */
.cb{display:flex;align-items:flex-start;gap:10px;margin:18px 0}.cb input{accent-color:var(--p1);margin-top:3px}.cb span{font-size:.65rem;color:var(--w4);line-height:1.5}
.gl{color:var(--p2);cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.disc{text-align:center;font-size:.45rem;color:var(--w4);letter-spacing:3px;text-transform:uppercase;padding:24px;line-height:1.8;font-weight:600}
.loading{display:flex;align-items:center;justify-content:center;padding:48px}
.spinner{width:28px;height:28px;border:2.5px solid rgba(139,92,246,.15);border-top-color:var(--p1);border-radius:50%;animation:spin .7s linear infinite}

/* Animations */
@keyframes glow-pulse{0%,100%{opacity:.6;box-shadow:0 0 8px rgba(6,182,212,.3)}50%{opacity:1;box-shadow:0 0 16px rgba(6,182,212,.6)}}
@keyframes orb-spin{to{transform:rotate(360deg)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}
@keyframes res-glow{0%,100%{transform:translate(0,0)}50%{transform:translate(5%,-5%)}}
@keyframes avatar-ring{to{transform:rotate(360deg)}}
.fade-up{animation:fadeUp .6s cubic-bezier(.16,1,.3,1)}
.slide-up{animation:slideUp .4s cubic-bezier(.16,1,.3,1)}

@media(min-width:431px){#app{box-shadow:0 0 100px rgba(139,92,246,.06),inset 0 0 100px rgba(0,0,0,.1)}}
