@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-heading:"Playfair Display", serif;--font-body:"Outfit", "Inter", sans-serif;--bg-obsidian:#05060b;--bg-deep-space:#0b0c15;--color-gold:#d4af37;--color-gold-hover:#f3e5ab;--color-purple:#7a42f4;--color-purple-glow:#7a42f466;--color-cyan:#0df;--color-pink:#f36;--color-green:#39ff14;--header-height:80px;--sidebar-width:280px;--glass-bg:#0b0c15a6;--glass-border:#ffffff0f;--glass-border-glow:#7a42f440;--transition-smooth:all .35s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-obsidian);color:#f0f2f5;font-family:var(--font-body);min-height:100vh;position:relative;overflow-x:hidden}body:before{content:"";opacity:.15;z-index:-2;background-image:radial-gradient(#fff,#fff3 2px,#0000 40px),radial-gradient(#fff,#ffffff26 1px,#0000 30px),radial-gradient(#fff,#ffffff1a 2px,#0000 40px);background-position:0 0,40px 60px,130px 270px;background-size:550px 550px,350px 350px,250px 250px;width:100%;height:100%;animation:120s linear infinite cosmicDrift;position:fixed;top:0;left:0}body:after{content:"";z-index:-1;pointer-events:none;background:radial-gradient(circle at 80% 20%,#7a42f426 0%,#0000 50%),radial-gradient(circle at 15% 80%,#00ddff14 0%,#0000 45%);width:100%;height:100%;position:fixed;top:0;left:0}@keyframes cosmicDrift{0%{background-position:0 0,40px 60px,130px 270px}to{background-position:550px 550px,390px 410px,380px 820px}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-obsidian)}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-purple)}h1,h2,h3,h4{font-family:var(--font-heading);letter-spacing:.5px;color:#fff}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);transition:var(--transition-smooth);border-radius:16px}.glass-panel-interactive:hover{border-color:var(--glass-border-glow);transform:translateY(-2px);box-shadow:0 8px 32px #7a42f414}.cosmic-input{color:#fff;width:100%;font-family:var(--font-body);transition:var(--transition-smooth);background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;outline:none;padding:12px 16px;font-size:15px}.cosmic-input option{background-color:var(--bg-deep-space);color:#fff}.cosmic-input:focus{border-color:var(--color-purple);box-shadow:0 0 14px var(--color-purple-glow);background:#7a42f40a}.cosmic-label{text-transform:uppercase;letter-spacing:1px;color:var(--color-gold);margin-bottom:8px;font-size:13px;font-weight:500;display:block}.btn-cosmic{background:linear-gradient(135deg, var(--color-purple) 0%, #522ad3 100%);color:#fff;font-family:var(--font-body);cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;padding:14px 28px;font-size:15px;font-weight:600;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #7a42f440}.btn-cosmic:before{content:"";background:linear-gradient(90deg,#0000,#ffffff40,#0000);width:100%;height:100%;transition:all .5s;position:absolute;top:0;left:-100%}.btn-cosmic:hover:before{left:100%}.btn-cosmic:hover{transform:translateY(-2px);box-shadow:0 6px 24px #7a42f466}.btn-cosmic:active{transform:translateY(1px)}.btn-gold{background:linear-gradient(135deg, var(--color-gold) 0%, #b28c1a 100%);color:#0c0b11;box-shadow:0 4px 20px #d4af3733}.btn-gold:hover{box-shadow:0 6px 24px #d4af3759}.glow-gold{color:var(--color-gold);text-shadow:0 0 10px #d4af3766}.glow-purple{color:var(--color-purple);text-shadow:0 0 12px var(--color-purple-glow)}.layout-container{max-width:1400px;margin:0 auto;padding:40px 20px}.tab-btn{color:#fff9;font-family:var(--font-body);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:12px;align-items:center;gap:10px;padding:14px 24px;font-size:15px;font-weight:500;display:flex}.tab-btn:hover{color:#fff;background:#ffffff08}.tab-btn.active{color:var(--color-gold);background:#d4af3714;border:1px solid #d4af3740;box-shadow:0 0 15px #d4af370d}.cosmic-loading{flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.spinner{border:3px solid #7a42f41a;border-top-color:var(--color-purple);width:50px;height:50px;box-shadow:0 0 15px var(--color-purple-glow);border-radius:50%;margin-bottom:20px;animation:1.2s cubic-bezier(.5,0,.5,1) infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}.mt-5{margin-top:32px}.mb-1{margin-bottom:6px}.mb-2{margin-bottom:12px}.mb-3{margin-bottom:18px}.mb-4{margin-bottom:24px}.pb-1{padding-bottom:6px}.pb-2{padding-bottom:12px}.pb-3{padding-bottom:18px}.w-100{width:100%}.text-muted{color:#ffffff80}.text-gold{color:var(--color-gold)}.font-sm{font-size:13px}.font-italic{font-style:italic}.font-bold{font-weight:700}.block{display:block}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.border-bottom{border-bottom:1px solid #ffffff14}.color-gold{color:var(--color-gold)!important}.color-cyan{color:var(--color-cyan)!important}.btn-cosmic.outline{color:#fffc;box-shadow:none;background:0 0;border:1px solid #7a42f466}.btn-cosmic.outline:hover{border-color:var(--color-purple);color:#fff;background:#7a42f414;box-shadow:0 4px 15px #7a42f433}.btn-cosmic:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important;transform:none!important}.upload-dropzone{transition:var(--transition-smooth);background:#ffffff03;border:2px dashed #ffffff14;border-radius:16px}.upload-dropzone:hover{background:#7a42f408;border-color:#7a42f459}.upload-label-wrapper{cursor:pointer;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:50px 30px;display:flex}.upload-label-wrapper h3{font-size:18px;font-weight:600}.upload-btn-styled{background:linear-gradient(135deg, var(--color-purple), #522ad3);color:#fff;cursor:pointer;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600;display:inline-block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cosmic-select-wrapper{width:100%;position:relative}.cosmic-select-trigger{color:#fff;width:100%;font-family:var(--font-body);text-align:left;cursor:pointer;transition:var(--transition-smooth);background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;outline:none;align-items:center;gap:10px;padding:12px 16px;font-size:15px;display:flex}.cosmic-select-trigger:hover{background:#7a42f408;border-color:#7a42f466}.cosmic-select-trigger.open{border-color:var(--color-purple);background:#7a42f40f;box-shadow:0 0 14px #7a42f433}.select-trigger-icon{color:#fff6;flex-shrink:0;align-items:center;display:flex}.select-trigger-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.select-chevron{color:#fff6;flex-shrink:0;transition:transform .25s}.select-chevron.rotated{color:var(--color-purple);transform:rotate(180deg)}.cosmic-select-menu{z-index:9999;background:#0e0f1c;border:1px solid #7a42f44d;border-radius:12px;width:100%;max-height:260px;padding:6px;animation:.18s ease-out menuSlideIn;position:absolute;top:calc(100% + 6px);left:0;overflow-y:auto;box-shadow:0 8px 40px #0009,0 0 20px #7a42f41a}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.cosmic-select-menu::-webkit-scrollbar{width:5px}.cosmic-select-menu::-webkit-scrollbar-track{background:0 0}.cosmic-select-menu::-webkit-scrollbar-thumb{background:#7a42f44d;border-radius:3px}.cosmic-select-option{text-align:left;color:#ffffffbf;width:100%;font-family:var(--font-body);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-radius:8px;padding:10px 14px;font-size:14px;transition:background .15s,color .15s;display:block;overflow:hidden}.cosmic-select-option:hover{color:#fff;background:#7a42f41f}.cosmic-select-option.active{color:var(--color-gold);background:#7a42f433;font-weight:600}.tuvi-tab{animation:.5s ease-out fadeIn}.text-center{text-align:center}.subtitle{color:#fff9;margin-top:8px;font-size:15px}.header-icon{margin-bottom:12px}.grid-form-content{grid-template-columns:320px 1fr;gap:30px;margin-top:40px;display:grid}@media (width<=1100px){.grid-form-content{grid-template-columns:1fr}}.form-container{border-color:#ffffff14;height:fit-content;padding:24px}.form-group{margin-bottom:20px}.flex-1{flex:1}.flex-2{flex:2}.row-inputs{gap:15px;display:flex}.input-with-icon{position:relative}.input-icon{color:#fff6;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-with-icon .cosmic-input{padding-left:42px}.cosmic-input.text-center{padding-left:4px;padding-right:4px}.cosmic-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cosmic-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cosmic-input[type=number]{-moz-appearance:textfield}select.cosmic-input{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg fill='white' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.gender-selector,.calendar-selector{background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;gap:4px;padding:4px;display:flex}.gender-btn,.calendar-btn{color:#fff9;font-family:var(--font-body);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:6px;flex:1;padding:8px 12px;font-size:13px;font-weight:500}.gender-btn.active,.calendar-btn.active{background:var(--color-purple);color:#fff;box-shadow:0 4px 12px #7a42f44d}.calendar-btn.active{background:var(--color-gold);color:#0c0b11;box-shadow:0 4px 12px #d4af3740}.spin{animation:2s linear infinite spin}.chart-loading{flex-direction:column;justify-content:center;align-items:center;padding:80px 40px;display:flex}.chart-loading h3{margin-bottom:8px}.chart-loading p{color:#ffffff80;text-align:center;max-width:400px;font-size:14px}.chart-dashboard{grid-template-columns:1fr 400px;align-items:start;gap:30px;display:grid}@media (width<=1300px){.chart-dashboard{grid-template-columns:1fr}}.tuvi-grid{aspect-ratio:1;grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr);gap:12px;width:100%;max-width:660px;margin:0 auto;display:grid;position:relative}.tam-hop-triangle{pointer-events:none;z-index:5;width:100%;height:100%;position:absolute;top:0;left:0}.tri-shadow{fill:none;stroke-width:1.8px;opacity:.12}.tri-main{fill:none;stroke-width:.55px;stroke-dasharray:4 3}.tri-hoa-shadow{stroke:#ff6b35}.tri-hoa{stroke:#ff6b35;fill:#ff6b350f;animation:4s ease-in-out infinite triGlow}.tri-moc-shadow{stroke:#39ff14}.tri-moc{stroke:#39ff14;fill:#39ff140d;animation:4s ease-in-out 1s infinite triGlow}.tri-thuy-shadow{stroke:#0df}.tri-thuy{stroke:#0df;fill:#00ddff0d;animation:4s ease-in-out 2s infinite triGlow}.tri-kim-shadow{stroke:#d4af37}.tri-kim{stroke:#d4af37;fill:#d4af370f;animation:4s ease-in-out 3s infinite triGlow}@keyframes triGlow{0%{stroke-opacity:.4;fill-opacity:.03;stroke-width:.5px}50%{stroke-opacity:1;fill-opacity:.1;stroke-width:.8px}to{stroke-opacity:.4;fill-opacity:.03;stroke-width:.5px}}@media (width<=600px){.tuvi-grid{gap:6px}}.palace-cell{cursor:pointer;z-index:2;border-color:#ffffff0d;flex-direction:column;justify-content:space-between;padding:12px;display:flex;position:relative}.center-cell{z-index:2;position:relative}.palace-cell.selected{border-color:var(--color-gold);background:#d4af370d;box-shadow:inset 0 0 15px #d4af3714,0 0 20px #d4af3726}.palace-header{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;margin-bottom:6px;padding-bottom:4px;display:flex}.cung-name{font-family:var(--font-heading);letter-spacing:.5px;color:var(--color-gold);font-size:11px;font-weight:700}.cung-diem{color:#fff9;background:#ffffff0f;border:1px solid #ffffff14;border-radius:4px;padding:1px 4px;font-size:9px}.palace-content{text-align:center;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;padding:4px 0;display:flex}.main-star{color:#fff;margin-bottom:6px;font-size:13px;font-weight:600}.star-dots{flex-wrap:wrap;justify-content:center;gap:3px;display:flex}.star-dot-badge{text-transform:uppercase;border-radius:3px;padding:1px 4px;font-size:8px;font-weight:500}.star-dot-badge.color-xanh{color:var(--color-cyan);background:#00ddff26;border:1px solid #00ddff4d}.star-dot-badge.color-do{color:var(--color-pink);background:#ff336626;border:1px solid #ff33664d}.star-dot-badge.color-vang{color:var(--color-gold);background:#d4af3726;border:1px solid #d4af374d}.star-dot-badge.color-trang{color:#e2e8f0;background:#ffffff14;border:1px solid #fff3}.star-more-badge{color:#fff6;padding:1px 2px;font-size:8px}.palace-footer{color:#ffffff59;text-align:right;border-top:1px solid #ffffff0a;margin-top:6px;padding-top:4px;font-size:9px}.center-cell{background:radial-gradient(circle,#7a42f414 0%,#05060bd9 100%);border:1px solid #d4af3740;border-radius:12px;flex-direction:column;grid-area:2/2/4/4;justify-content:space-between;padding:16px;display:flex;box-shadow:0 0 25px #7a42f40d,inset 0 0 15px #d4af370a}.center-header{border-bottom:1px solid #d4af3726;flex-direction:column;align-items:center;gap:6px;padding-bottom:10px;display:flex}.center-header h3{letter-spacing:1px;text-shadow:0 0 12px #d4af374d;font-size:15px;font-weight:700}.badge-gender{border:1px solid var(--color-gold);color:var(--color-gold);letter-spacing:.5px;background:#d4af371a;border-radius:20px;padding:2px 8px;font-size:9px;font-weight:600}.center-body{flex-direction:column;gap:8px;margin:12px 0;display:flex}.info-row{border-bottom:1px dashed #ffffff0d;justify-content:space-between;padding-bottom:4px;font-size:10px;display:flex}.info-row.highlight .val{color:var(--color-gold);text-shadow:0 0 8px #d4af3733;font-weight:600}.info-row .lbl{color:#ffffff73}.info-row .val{color:#f0f2f5;font-weight:500}.center-footer{letter-spacing:1.5px;color:var(--color-gold);border-top:1px solid #d4af3726;justify-content:center;align-items:center;gap:6px;padding-top:10px;font-size:9px;font-weight:600;display:flex}.palace-detail-panel{border-color:#ffffff14;height:660px;padding:24px;overflow-y:auto}.detail-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;display:flex}.detail-header h2{letter-spacing:.5px;color:#fff;font-size:20px}.detail-header .sub{color:#ffffff73;margin-top:4px;font-size:13px}.diem-gauge{border:1px solid var(--color-purple);width:54px;height:54px;box-shadow:0 0 15px var(--color-purple-glow);background:radial-gradient(circle,#7a42f426 0%,#0000 100%);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;display:flex}.gauge-val{color:#fff;font-size:16px;font-weight:700;line-height:1}.gauge-lbl{text-transform:uppercase;color:#ffffff80;margin-top:2px;font-size:7px}.detail-section{margin-bottom:24px}.section-title{text-transform:uppercase;letter-spacing:1px;color:var(--color-gold);border-left:2px solid var(--color-gold);margin-bottom:12px;padding-left:8px;font-size:13px}.major-hanh-card{background:#ffffff05;border:1px solid #ffffff0f;border-radius:10px;padding:14px 18px;font-size:15px}.stars-grid{flex-direction:column;gap:12px;display:flex}.star-card{transition:var(--transition-smooth);background:#ffffff05;border:1px solid #ffffff0f;border-left:3px solid;border-radius:10px;padding:12px 16px}.star-card:hover{background:#ffffff0a}.star-card.border-color-xanh{border-left-color:var(--color-cyan)}.star-card.border-color-do{border-left-color:var(--color-pink)}.star-card.border-color-vang{border-left-color:var(--color-gold)}.star-card.border-color-trang{border-left-color:#fff6}.star-card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.star-icon.color-xanh{color:var(--color-cyan);filter:drop-shadow(0 0 4px #00ddff80)}.star-icon.color-do{color:var(--color-pink);filter:drop-shadow(0 0 4px #ff336680)}.star-icon.color-vang{color:var(--color-gold);filter:drop-shadow(0 0 4px #d4af3780)}.star-icon.color-trang{color:#fff;filter:drop-shadow(0 0 4px #ffffff80)}.star-name{color:#fff;font-size:14px;font-weight:600}.star-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:1px 4px;font-size:7px;font-weight:600}.star-badge.bg-chinh_tinh{color:#9d7df7;background:#7a42f426;border:1px solid #7a42f44d}.star-badge.bg-phu_tinh{color:#fff9;background:#ffffff0d;border:1px solid #ffffff26}.star-badge.bg-sat_tinh{color:var(--color-pink);background:#ff336626;border:1px solid #ff33664d}.star-meaning{color:#fff9;font-size:12px;line-height:1.45}.empty-detail-state{flex-direction:column;justify-content:center;align-items:center;height:100%;padding:40px;display:flex}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}.empty-detail-state h3{margin-bottom:10px}.empty-detail-state p{color:#ffffff73;max-width:320px;font-size:13px;line-height:1.5}.CircularProgressbar{vertical-align:middle;width:100%}.CircularProgressbar .CircularProgressbar-path{stroke:#3e98c7;stroke-linecap:round;transition:stroke-dashoffset .5s}.CircularProgressbar .CircularProgressbar-trail{stroke:#d6d6d6;stroke-linecap:round}.CircularProgressbar .CircularProgressbar-text{fill:#3e98c7;dominant-baseline:middle;text-anchor:middle;font-size:20px}.CircularProgressbar .CircularProgressbar-background{fill:#d6d6d6}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-background{fill:#3e98c7}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-text{fill:#fff}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-path{stroke:#fff}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-trail{stroke:#0000}.palm-tab{animation:.5s ease-out fadeIn}.palm-dashboard{grid-template-columns:460px 1fr;align-items:start;gap:30px;margin-top:40px;display:grid}@media (width<=950px){.palm-dashboard{grid-template-columns:1fr}}.palm-interactive-box{padding:24px}.rule-warning-alert{color:#fff;background:#d4af370d;border:1px solid #d4af3726;border-radius:8px;align-items:center;gap:10px;padding:12px 16px;font-size:13px;display:flex}.upload-dropzone{text-align:center;cursor:pointer;transition:var(--transition-smooth);background:#ffffff03;border:2px dashed #d4af3733;border-radius:16px;padding:40px 20px}.upload-dropzone:hover{border-color:var(--color-gold);background:#d4af3708}.upload-icon{margin-bottom:16px;animation:2s infinite pulse}@keyframes pulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}to{opacity:.8;transform:scale(1)}}.upload-btn-styled{background:linear-gradient(135deg, var(--color-gold) 0%, #b28c1a 100%);color:#05060b;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600;display:inline-block;box-shadow:0 4px 12px #d4af3740}.drawing-workspace{flex-direction:column;align-items:center;width:100%;display:flex}.interactive-canvas-container{width:100%;max-width:400px;position:relative}.palm-preview-image{object-fit:cover;width:100%;height:100%;display:block}.tracing-canvas{z-index:10;cursor:grab;width:100%;height:100%;position:absolute;top:0;left:0}.tracing-image-wrapper{aspect-ratio:4/5;touch-action:none;background:#000;border:1px solid #ffffff14;border-radius:12px;width:100%;position:relative;overflow:hidden;box-shadow:0 10px 30px #00000080}.tracing-canvas:active{cursor:grabbing}.progress-bars-container{justify-content:space-around;width:100%;padding-top:15px;display:flex}.progress-bar-item{cursor:pointer;flex-direction:column;align-items:center;transition:transform .2s;display:flex}.progress-bar-item:hover{transform:scale(1.1)}.progress-label{text-transform:uppercase;margin-top:5px;font-size:11px;font-weight:600}.workspace-controls{gap:15px;width:100%;max-width:400px;margin-top:20px;display:flex}.btn-cosmic.outline{box-shadow:none;background:0 0;border:1px solid #ffffff26}.btn-cosmic.outline:hover{background:#ffffff0d;border-color:#fff}.palm-results-panel{min-height:500px}.guidelines-card{border-color:#ffffff14;padding:24px}.guide-buttons-list{flex-direction:column;gap:12px;display:flex}.guide-line-item{text-align:left;cursor:pointer;transition:var(--transition-smooth);background:#ffffff05;border:1px solid #ffffff0d;border-left:4px solid;border-radius:8px;padding:14px}.guide-line-item:hover{background:#ffffff0a}.guide-line-item.active{background:#ffffff0d;border-color:#ffffff1f;box-shadow:0 4px 15px #0003}.guide-line-header{font-size:14px;font-weight:600}.guide-line-desc{color:#ffffff80;font-size:12px;line-height:1.4}.empty-panel{flex-direction:column;justify-content:center;align-items:center;padding:80px 40px;display:flex}.reading-results{border-color:#ffffff14;padding:24px}.results-header{align-items:center;gap:15px;padding-bottom:16px;display:flex}.results-header h2{font-size:20px}.results-header .sub{font-size:13px}.results-tarot-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}@media (width<=600px){.results-tarot-grid{grid-template-columns:1fr}}.tarot-card{perspective:1000px;cursor:pointer;height:170px}.tarot-card-inner{text-align:center;width:100%;height:100%;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.4,0,.2,1);position:relative}.tarot-card:hover .tarot-card-inner{transform:rotateY(180deg)}.tarot-card-front,.tarot-card-back{backface-visibility:hidden;border:1px solid #ffffff0f;border-radius:12px;flex-direction:column;justify-content:space-between;align-items:center;width:100%;height:100%;padding:16px;display:flex;position:absolute}.tarot-card-front{color:#fff;background:linear-gradient(145deg,#0e0f17 0%,#151025 100%);border:1px solid #7a42f426}.tarot-card.active .tarot-card-front{background:linear-gradient(145deg,#0d0b13 0%,#201a08 100%);border-color:#d4af3740}.tarot-card-front .card-symbol{color:var(--color-purple);filter:drop-shadow(0 0 8px var(--color-purple-glow))}.tarot-card.active .tarot-card-front .card-symbol{color:var(--color-gold);filter:drop-shadow(0 0 8px #d4af374d)}.card-title{font-family:var(--font-heading);letter-spacing:.5px;text-align:center;font-size:13px;font-weight:700}.card-status-badge{color:#fff9;letter-spacing:.5px;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:4px;padding:2px 8px;font-size:8px;font-weight:600}.tarot-card.active .card-status-badge{border-color:var(--color-gold);color:var(--color-gold);background:#d4af371a}.tarot-card-back{color:#ffffffbf;text-align:left;background:#0f1019;border-color:#ffffff1a;justify-content:center;align-items:center;display:flex;transform:rotateY(180deg)}.card-explanation{text-align:justify;font-size:11px;line-height:1.5}.auto-fit-scanning-overlay{z-index:20;background:#05060b8c;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:absolute;inset:0}.auto-fit-scanning-overlay span{color:var(--color-cyan);text-shadow:0 0 10px #00ddff80;letter-spacing:.5px;font-size:13px;font-weight:500}.scan-pulse-ring{border:3px solid var(--color-cyan);border-radius:50%;width:72px;height:72px;animation:1s ease-in-out infinite scanPulse;box-shadow:0 0 18px #0df6,inset 0 0 12px #00ddff26}@keyframes scanPulse{0%{opacity:.5;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}to{opacity:.5;transform:scale(.85)}}.auto-fit-success-badge{width:100%;max-width:400px;color:var(--color-green);background:#39ff1412;border:1px solid #39ff1433;border-radius:8px;align-items:center;gap:8px;margin-top:10px;padding:8px 14px;font-size:12px;display:flex}.auto-fit-btn{color:var(--color-cyan)!important;border-color:#00ddff4d!important}.auto-fit-btn:hover{border-color:var(--color-cyan)!important;background:#00ddff0f!important;box-shadow:0 0 12px #00ddff26!important}.face-tab{width:100%;animation:.6s ease-out fadeIn}.face-dashboard{grid-template-columns:450px 1fr;align-items:start;gap:30px;margin-top:30px;display:grid}@media (width<=1100px){.face-dashboard{grid-template-columns:1fr}}.tab-header{margin-bottom:25px}.tab-header h2{background:linear-gradient(135deg, #fff 30%, var(--color-gold) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:10px 0;font-size:28px;font-weight:700}.tab-header .subtitle{color:#fff9;max-width:700px;margin:0 auto;font-size:15px}.face-interactive-box{padding:30px}.face-results-panel{min-height:500px;position:relative}.triple-upload-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}@media (width<=480px){.triple-upload-grid{grid-template-columns:1fr}}.upload-card{transition:var(--transition-smooth);background:#ffffff05;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;align-items:center;padding:12px;display:flex}.upload-card.has-image{border-color:var(--color-purple-glow);background:#7a42f408}.upload-title{color:var(--color-gold);text-transform:uppercase;letter-spacing:.5px;text-align:center;margin-bottom:10px;font-size:11px;font-weight:600}.upload-box-wrapper{aspect-ratio:3/4;width:100%;transition:var(--transition-smooth);background:#ffffff03;border:1.5px dashed #ffffff1a;border-radius:8px;position:relative;overflow:hidden}.upload-box-wrapper:hover{border-color:var(--color-purple);background:#7a42f40d}.upload-box-label{cursor:pointer;color:#ffffff73;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;font-size:11px;font-weight:500;display:flex}.upload-subicon{color:var(--color-gold);opacity:.7;transition:var(--transition-smooth)}.upload-box-label:hover .upload-subicon{opacity:1;transform:scale(1.1)}.side-profile{transform:scaleX(-1)}.preview-container{width:100%;height:100%;position:relative}.face-thumb{object-fit:cover;width:100%;height:100%}.remove-preview-btn{color:#fff;cursor:pointer;width:20px;height:20px;transition:var(--transition-smooth);background:#ff3366d9;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:12px;line-height:1;display:flex;position:absolute;top:5px;right:5px}.remove-preview-btn:hover{background:#f36;transform:scale(1.1)}.face-action-controls{gap:15px;display:flex}.scanning-overlay{border:1px solid var(--color-purple-glow);background:#0b0c15d9;flex-direction:column;justify-content:center;align-items:center;min-height:500px;padding:50px 30px;display:flex;box-shadow:0 0 35px #7a42f426}.scanner-container{background:radial-gradient(circle,#7a42f414 0%,#0000 70%);border:2px solid #7a42f433;border-radius:50%;width:220px;height:220px;position:relative;overflow:hidden}.scanner-line{background:linear-gradient(90deg, transparent, var(--color-purple), #fff, var(--color-purple), transparent);width:100%;height:4px;box-shadow:0 0 15px var(--color-purple);animation:3s ease-in-out infinite scanVertical;position:absolute;top:0}.scanner-hologram{background-image:radial-gradient(circle, transparent 50%, var(--color-purple-glow) 52%, transparent 55%), radial-gradient(circle, transparent 30%, var(--color-cyan) 31%, transparent 33%);opacity:.5;border-radius:50%;width:70%;height:70%;animation:10s linear infinite rotateHolo;position:absolute;top:15%;left:15%}@keyframes scanVertical{0%{top:0%}50%{top:100%}to{top:0%}}@keyframes rotateHolo{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-step-text{color:var(--color-cyan);text-shadow:0 0 8px #00ddff4d;min-height:22px;font-size:14px;font-style:italic}.progress-bar-container{background:#ffffff0f;border-radius:3px;width:280px;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--color-purple) 0%, var(--color-cyan) 100%);height:100%;box-shadow:0 0 10px var(--color-purple);border-radius:3px;transition:width .4s ease-out}.empty-panel{flex-direction:column;justify-content:center;align-items:center;height:100%;padding:80px 40px;display:flex}.empty-icon{margin-bottom:25px;animation:2.5s ease-in-out infinite pulseGold}@keyframes pulseGold{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;filter:drop-shadow(0 0 12px #d4af3766);transform:scale(1.08)}}.empty-panel h3{margin-bottom:12px;font-size:20px;font-weight:600}.empty-panel p{color:#ffffff8c;max-width:500px;font-size:14px;line-height:1.6}.grand-report-box{background:linear-gradient(135deg,#d4af371a 0%,#ffffff05 50%,#7a42f414 100%);border:1px solid #d4af3726;border-radius:20px;padding:4px}.scroll-paper-texture{background:radial-gradient(circle,#11121b 0%,#08090f 100%);border-radius:16px;padding:35px;position:relative;overflow:hidden}.scroll-paper-texture:before{content:"";background:linear-gradient(90deg,#0000,#d4af374d,#0000);height:1px;position:absolute;top:0;left:0;right:0}.scroll-header{border-bottom:1px solid #d4af3726;align-items:center;gap:15px;padding-bottom:18px;display:flex}.scroll-header h2{letter-spacing:2px;background:linear-gradient(90deg, #fff 0%, var(--color-gold) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:20px;font-weight:700}.conclusion-para{color:#ffffffd9;margin-bottom:22px;font-size:15px;line-height:1.7}.block-header{text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:15px;display:inline-block}.block-content{opacity:.9;font-weight:300;display:block}.face-details-grid{grid-template-columns:1fr 1fr;gap:25px;display:grid}@media (width<=768px){.face-details-grid{grid-template-columns:1fr}}.features-checklist,.diagnostics-checklist{padding:25px}.panel-title{letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid #ffffff14;font-size:16px;font-weight:600}.feature-badges-list{flex-direction:column;gap:12px;display:flex}.feature-badge-row{transition:var(--transition-smooth);background:#ffffff05;border:1px solid #ffffff0a;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;display:flex}.feature-badge-row:hover{background:#ffffff0a;border-color:#ffffff14}.badge-lbl{color:#fff9;font-weight:500}.badge-val{color:var(--color-cyan);text-transform:capitalize;text-shadow:0 0 6px #0df3;font-weight:600}.accordion-diagnostics-list{flex-direction:column;gap:15px;display:flex}.diagnostic-card{transition:var(--transition-smooth);background:#ffffff05;border:1px solid #ffffff0a;border-radius:12px;padding:15px}.diagnostic-card:hover{background:#ffffff08;border-color:#ffffff14}.diagnostic-header{align-items:flex-start;gap:12px;display:flex}.chk-icon{flex-shrink:0;margin-top:2px}.chk-q-wrapper{flex-direction:column;gap:4px;display:flex}.chk-question{color:#fff;font-size:13.5px;font-weight:500;line-height:1.4}.chk-badge{letter-spacing:.5px;border-radius:20px;align-self:flex-start;padding:3px 8px;font-size:10px;font-weight:700;display:inline-block}.chk-badge.yes{color:var(--color-green);background:#39ff141a;border:1px solid #39ff1433}.chk-badge.no{color:var(--color-pink);background:#ff33661a;border:1px solid #f363}.chk-conclusion{color:#ffffffa6;border-left:2px solid #ffffff1a;padding-left:10px;font-size:12.5px;font-weight:300;line-height:1.6}.fade-in{animation:.4s ease-out forwards fadeIn}.color-green{color:var(--color-green)!important}.color-pink{color:var(--color-pink)!important}.upload-box-content{color:#ffffff73;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:70%;font-size:11px;font-weight:500;display:flex}.upload-subtext{color:#fff9;font-size:11px}.upload-box-actions{box-sizing:border-box;justify-content:center;align-items:center;gap:8px;width:100%;height:30%;padding-bottom:8px;display:flex}.action-btn{width:30px;height:30px;color:var(--color-gold);cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;justify-content:center;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.action-btn:hover{border-color:var(--color-purple);color:#fff;background:#7a42f426;transform:translateY(-2px);box-shadow:0 4px 10px #7a42f440}.camera-modal-overlay{-webkit-backdrop-filter:blur(10px);z-index:1000;background:#08090fd9;justify-content:center;align-items:center;padding:20px;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.camera-modal-content{background:linear-gradient(135deg,#141523e6 0%,#0a0b14f2 100%);border:1px solid #d4af3740;border-radius:20px;flex-direction:column;width:100%;max-width:440px;display:flex;overflow:hidden;box-shadow:0 10px 40px #0009,0 0 30px #7a42f426}.camera-modal-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.camera-modal-header h3{margin:0;font-size:16px;font-weight:600}.camera-modal-close{color:#ffffff80;cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;padding:0;font-size:24px;line-height:1}.camera-modal-close:hover{color:var(--color-pink);transform:scale(1.1)}.camera-viewfinder-container{background:#0003;justify-content:center;align-items:center;padding:20px;display:flex}.camera-viewfinder{aspect-ratio:3/4;background:#000;border:1px solid #ffffff0d;border-radius:12px;width:100%;max-width:320px;position:relative;overflow:hidden;box-shadow:0 0 25px #00000080,inset 0 0 20px #7a42f433}.camera-video-stream{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.camera-shutter-flash{opacity:0;pointer-events:none;z-index:5;background:#fff;width:100%;height:100%;position:absolute;top:0;left:0}.camera-shutter-flash.active{animation:.3s ease-out flashEffect}@keyframes flashEffect{0%{opacity:1}to{opacity:0}}.camera-guide-overlay{pointer-events:none;z-index:2;box-sizing:border-box;flex-direction:column;justify-content:space-between;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.face-guide-oval{transition:var(--transition-smooth);border:2px dashed #d4af3773;border-radius:50% 50% 48% 48%/55% 55% 45% 45%;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:15% 12% 20%;box-shadow:0 0 0 9999px #00000073}.camera-viewfinder:hover .face-guide-oval{border-color:var(--color-gold);filter:drop-shadow(0 0 8px #d4af3766);border-style:solid}.guide-eyes-line{border-top:1px dotted #d4af374d;height:1px;position:absolute;top:40%;left:10%;right:10%}.guide-mouth-line{border-top:1px dotted #d4af374d;height:1px;position:absolute;bottom:25%;left:25%;right:25%}.guide-smile-curve{border-bottom:2px solid #d4af378c;border-radius:0 0 20px 20px;width:30px;height:12px;position:absolute;bottom:23%}.guide-tip-text{text-align:center;color:#ffffffd9;letter-spacing:.5px;text-shadow:0 1px 4px #00000080;background:#08090fb3;border:1px solid #ffffff14;border-radius:20px;padding:6px 12px;font-size:11px;font-weight:500;animation:2s ease-in-out infinite pulseTip;position:absolute;bottom:-45px;left:-20px;right:-20px}@keyframes pulseTip{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;border-color:#d4af374d;transform:scale(1.03)}}.face-guide-profile{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0;box-shadow:inset 0 0 60px #7a42f44d}.left-profile-guide{background:radial-gradient(circle at 35%,#0000 40%,#0009 80%)}.left-profile-guide:before{content:"";border-left:2px dashed #0df6;border-radius:40% 0 0 40%/50% 0 0 50%;width:50%;height:65%;position:absolute;top:15%;left:20%}.right-profile-guide{background:radial-gradient(circle at 65%,#0000 40%,#0009 80%)}.right-profile-guide:before{content:"";border-right:2px dashed #0df6;border-radius:0 40% 40% 0/0 50% 50% 0;width:50%;height:65%;position:absolute;top:15%;right:20%}.camera-viewfinder:hover .face-guide-profile:before{border-color:var(--color-cyan);filter:drop-shadow(0 0 6px #0df6)}.camera-modal-controls{border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px 20px;display:flex}.camera-modal-controls .btn-cosmic{padding:10px 18px;font-size:13px;font-weight:600}.toggle-cam-btn{align-items:center;gap:6px;display:flex}.app-shell{flex-direction:column;gap:30px;max-width:1440px;min-height:100vh;margin:0 auto;padding:20px 40px;display:flex;position:relative}@media (width<=768px){.app-shell{gap:20px;padding:15px}}.aurora-glow-1{z-index:-2;filter:blur(80px);pointer-events:none;background:radial-gradient(circle,#7a42f41f 0%,#0000 60%);width:50vw;height:50vw;animation:25s ease-in-out infinite floatSlow;position:fixed;top:-10%;left:20%}.aurora-glow-2{z-index:-2;filter:blur(80px);pointer-events:none;background:radial-gradient(circle,#00ddff0f 0%,#0000 65%);width:45vw;height:45vw;animation:30s ease-in-out infinite floatSlowAlt;position:fixed;bottom:-10%;right:10%}@keyframes floatSlow{0%,to{transform:translate(0)scale(1)}50%{transform:translate(60px,-40px)scale(1.15)}}@keyframes floatSlowAlt{0%,to{transform:translate(0)scale(1.1)}50%{transform:translate(-80px,40px)scale(.9)}}.spin-slow{animation:20s linear infinite spinSlow}@keyframes spinSlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cosmic-header{z-index:100;border-color:#ffffff0d;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:15px;box-shadow:0 4px 30px #0000004d}@media (width<=768px){.cosmic-header{flex-direction:column;gap:15px;padding:15px;top:5px}}.header-brand{align-items:center;gap:12px;display:flex}@media (width<=480px){.header-brand{text-align:center;flex-direction:column;gap:8px}}.brand-icon{filter:drop-shadow(0 0 8px #d4af3766)}.brand-title{letter-spacing:2px;background:linear-gradient(135deg, #fff 0%, var(--color-gold) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:20px;font-weight:800}.brand-tagline{text-transform:uppercase;letter-spacing:2.5px;color:#ffffff80;margin-top:1px;font-size:10px;font-weight:500;display:block}.header-nav{background:#ffffff08;border:1px solid #ffffff0d;border-radius:14px;gap:12px;padding:6px;display:flex}@media (width<=480px){.header-nav{justify-content:space-around;width:100%;padding:4px}.tab-btn span{display:none}}.welcome-banner{background:radial-gradient(circle at 10% 20%,#d4af370d 0%,#7a42f408 60%,#0000 100%);border-color:#d4af371f;padding:45px;position:relative;overflow:hidden}@media (width<=768px){.welcome-banner{padding:30px 20px}}.banner-bg-stars{opacity:.25;pointer-events:none;background-image:radial-gradient(#d4af3733 1.5px,#0000 1.5px);background-size:30px 30px;width:100%;height:100%;position:absolute;top:0;left:0}.welcome-content{z-index:2;flex-direction:column;gap:15px;max-width:800px;display:flex;position:relative}.welcome-badge{text-transform:uppercase;letter-spacing:1px;color:var(--color-gold);background:#d4af3714;border:1px solid #d4af3733;border-radius:30px;align-self:flex-start;align-items:center;gap:8px;padding:6px 14px;font-size:11px;font-weight:600;display:inline-flex}.welcome-content h2{background:linear-gradient(135deg, #fff 40%, var(--color-gold) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:36px;font-weight:700;line-height:1.25}@media (width<=480px){.welcome-content h2{font-size:26px}}.welcome-content p{color:#ffffffb3;font-size:15.5px;font-weight:300;line-height:1.7}.welcome-actions{gap:15px;margin-top:10px;display:flex}@media (width<=480px){.welcome-actions{flex-direction:column}}.main-content-panel{min-height:600px}.cosmic-footer{border-top:1px solid #ffffff0d;flex-direction:column;gap:10px;margin-top:60px;padding:30px 20px;display:flex}.footer-credits{color:#ffffff73;font-size:13.5px;font-weight:500}.footer-disclaimer{color:#ffffff40;max-width:800px;margin:0 auto;font-size:11px;line-height:1.6}
