*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--cream:#FAF7F2;--blush:#EFCFC4;--rose:#C8685A;--deep-rose:#9B3E30;--sage:#8BA888;--muted:#9C9088;--ink:#2B1810;--soft-ink:#5C4A42;--gold:#C8A45E;--card:#FFFBF8}
html,body{height:100%;background:var(--cream);color:var(--ink);overflow-x:hidden}
body{font-family:'DM Sans',sans-serif;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 55% 45% at 15% 15%,rgba(239,207,196,.5) 0%,transparent 65%),radial-gradient(ellipse 45% 55% at 85% 85%,rgba(139,168,136,.25) 0%,transparent 65%),radial-gradient(ellipse 35% 35% at 70% 10%,rgba(200,164,94,.2) 0%,transparent 55%)}
#site-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid rgba(43,24,16,.07);background:rgba(250,247,242,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
#logo{display:flex;align-items:center;gap:10px;cursor:pointer}
#logo-img{height:36px;width:auto;display:block}
#logo-tagline{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
#app{position:relative;z-index:1;flex:1;display:flex;align-items:center;justify-content:center;padding:32px 20px 48px}
.screen{display:none;width:100%;max-width:520px}
.screen.active{display:block;animation:riseIn 0.5s cubic-bezier(.16,1,.3,1) both}
@keyframes riseIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.progress{display:flex;gap:6px;margin-bottom:24px}
.dot{width:6px;height:6px;border-radius:50%;background:rgba(43,24,16,.15);transition:all 0.35s cubic-bezier(.34,1.56,.64,1)}
.dot.active{background:var(--rose);width:22px;border-radius:4px}
.dot.done{background:var(--sage)}
.step-label{font-size:10.5px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px;margin-bottom:14px}
.step-label::after{content:'';flex:1;height:1px;background:linear-gradient(to right,rgba(156,144,136,.3),transparent)}
.question{font-family:'Playfair Display',serif;font-size:clamp(24px,6vw,36px);line-height:1.18;color:var(--ink);margin-bottom:8px}
.question em{color:var(--rose);font-style:italic}
.sub{font-size:14px;color:var(--muted);margin-bottom:28px}
.pills{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:32px}
.pill{padding:10px 18px;border-radius:50px;border:1.5px solid rgba(43,24,16,.11);background:rgba(255,255,255,.65);backdrop-filter:blur(12px);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:400;color:var(--soft-ink);cursor:pointer;transition:all 0.2s cubic-bezier(.34,1.56,.64,1);user-select:none;-webkit-tap-highlight-color:transparent}
.pill:hover{border-color:var(--rose);background:rgba(239,207,196,.35);transform:translateY(-2px);box-shadow:0 5px 18px rgba(200,104,90,.16)}
.pill.selected{background:var(--rose);border-color:var(--rose);color:#fff;transform:translateY(-2px);box-shadow:0 7px 22px rgba(200,104,90,.38)}
.pill.multi.selected{background:var(--ink);border-color:var(--ink);color:#fff;box-shadow:0 6px 20px rgba(43,24,16,.25)}
.next-btn{display:inline-flex;align-items:center;gap:10px;padding:13px 28px;background:var(--ink);color:#fff;border:none;border-radius:50px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;transition:all 0.22s ease;opacity:0;transform:translateY(10px);pointer-events:none;-webkit-tap-highlight-color:transparent}
.next-btn.show{opacity:1;transform:translateY(0);pointer-events:all;animation:popIn 0.38s cubic-bezier(.34,1.56,.64,1)}
@keyframes popIn{from{opacity:0;transform:translateY(12px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}
.next-btn:hover{background:var(--rose);transform:translateY(-2px);box-shadow:0 10px 28px rgba(200,104,90,.38)}
.next-btn svg{transition:transform 0.18s}
.next-btn:hover svg{transform:translateX(4px)}
#screen-loading{text-align:center;padding:60px 0 50px}
.loader-wrap{display:inline-block;position:relative;width:88px;height:88px;margin-bottom:32px}
.glow-ring{position:absolute;inset:-14px;border-radius:50%;border:1.5px solid rgba(200,104,90,.22);animation:pulsate 1.8s ease-in-out infinite}
@keyframes pulsate{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.08);opacity:1}}
.blossom-svg{animation:rotateSlow 4s linear infinite}
.blossom-inner{animation:rotateSlow 2.5s linear infinite reverse;transform-origin:44px 44px}
@keyframes rotateSlow{to{transform:rotate(360deg)}}
.loading-title{font-family:'Playfair Display',serif;font-size:21px;color:var(--ink);margin-bottom:8px}
.loading-sub{font-size:13px;color:var(--muted);letter-spacing:.05em}
#daily-vibe-section{margin-top:36px;padding-top:28px;border-top:1px solid rgba(43,24,16,.08)}
#dv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
#dv-label-wrap{display:flex;align-items:center;gap:8px}
#dv-dot{width:7px;height:7px;border-radius:50%;background:var(--rose);animation:pulsate 2s ease-in-out infinite}
#dv-eyebrow{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;color:var(--ink)}
#dv-date{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
#dv-card{display:grid;grid-template-columns:90px 1fr;gap:14px;align-items:start;background:var(--card);border-radius:14px;padding:14px;box-shadow:0 4px 24px rgba(43,24,16,.08);transition:box-shadow 0.22s}
#dv-card:hover{box-shadow:0 8px 32px rgba(43,24,16,.13)}
#dv-poster-wrap{position:relative;border-radius:8px;overflow:hidden;background:linear-gradient(145deg,var(--blush),rgba(200,104,90,.3));aspect-ratio:2/3}
#dv-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px}
#dv-poster-img{width:100%;height:100%;object-fit:cover;display:block}
#dv-info{display:flex;flex-direction:column;gap:6px;padding-top:2px}
#dv-title{font-family:'Playfair Display',serif;font-size:15px;color:var(--ink);line-height:1.2;font-weight:600}
#dv-meta{display:flex;align-items:center;gap:10px}
#dv-year{font-size:11px;color:var(--muted)}
#dv-rating{display:flex;align-items:center;gap:3px;font-size:11px;color:var(--gold);font-weight:500}
#dv-summary{font-size:12px;line-height:1.55;color:var(--soft-ink);font-style:italic}
#dv-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.dv-tag{padding:2px 9px;border-radius:50px;background:rgba(200,104,90,.1);color:var(--rose);font-size:10px;font-weight:500}
.dv-watch-btn{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:8px 16px;background:linear-gradient(135deg,var(--rose),var(--deep-rose));color:#fff;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;border-radius:8px;text-decoration:none;transition:all 0.2s;-webkit-tap-highlight-color:transparent}
.dv-watch-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(200,104,90,.36)}
.dv-skel{background:linear-gradient(90deg,rgba(43,24,16,.07) 25%,rgba(43,24,16,.12) 50%,rgba(43,24,16,.07) 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:6px}
.dv-skel-title{height:14px;width:75%;margin-bottom:6px}
.dv-skel-sm{height:10px;width:45%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.collection-eyebrow{font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.result-layout{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:start;background:var(--card);border-radius:16px;padding:16px;box-shadow:0 8px 40px rgba(43,24,16,.1);margin-bottom:16px}
.poster-wrap{position:relative;border-radius:10px;overflow:hidden;box-shadow:0 8px 24px rgba(43,24,16,.18);background:linear-gradient(145deg,var(--blush),rgba(200,104,90,.3))}
.poster-wrap img{width:100%;display:block;aspect-ratio:2/3;object-fit:cover}
.poster-ph{width:100%;aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;font-size:40px}
.poster-badge{position:absolute;top:8px;left:8px;background:rgba(43,24,16,.72);backdrop-filter:blur(10px);color:#fff;font-size:8px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:3px 9px;border-radius:50px}
.info-col{display:flex;flex-direction:column;padding-top:2px}
.drama-title{font-family:'Playfair Display',serif;font-size:clamp(16px,3.5vw,20px);color:var(--ink);margin-bottom:5px;line-height:1.2}
.drama-meta{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.drama-year{font-size:11px;color:var(--muted)}
.drama-rating{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--gold);font-weight:500}
.vibe-summary{font-size:12px;line-height:1.6;color:var(--soft-ink);margin-bottom:8px;font-style:italic;border-left:2px solid var(--blush);padding-left:10px}
.trope-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.trope-tag{padding:2px 9px;border-radius:50px;background:rgba(200,104,90,.1);color:var(--rose);font-size:10px;font-weight:500}
.card-watermark{font-size:9px;color:var(--muted);letter-spacing:.08em;margin-top:auto;padding-top:8px;opacity:.7}
.alt-eyebrow{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
#alt-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:0}
.alt-card{background:var(--card);border-radius:12px;padding:12px;box-shadow:0 4px 16px rgba(43,24,16,.07);display:grid;grid-template-columns:56px 1fr;gap:10px;align-items:start;transition:box-shadow 0.2s}
.alt-card:hover{box-shadow:0 8px 24px rgba(43,24,16,.12)}
.alt-poster{border-radius:6px;overflow:hidden;background:linear-gradient(145deg,var(--blush),rgba(200,104,90,.3));position:relative}
.alt-poster img{width:100%;display:block;aspect-ratio:2/3;object-fit:cover}
.alt-poster-ph{width:100%;aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;font-size:20px}
.alt-info{display:flex;flex-direction:column;gap:4px;padding-top:2px}
.alt-title{font-family:'Playfair Display',serif;font-size:12px;color:var(--ink);line-height:1.2;font-weight:600}
.alt-meta{font-size:10px;color:var(--muted)}
.alt-rating{font-size:10px;color:var(--gold);font-weight:500}
.alt-watch{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:5px 10px;background:linear-gradient(135deg,var(--rose),var(--deep-rose));color:#fff;font-family:'DM Sans',sans-serif;font-size:10px;font-weight:500;border-radius:6px;text-decoration:none;transition:background 0.25s ease,transform 0.2s ease;-webkit-tap-highlight-color:transparent}
.alt-watch:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(200,104,90,.36)}
.result-actions{display:flex;gap:10px;margin-top:14px;margin-bottom:12px}
.watch-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border:none;border-radius:12px;cursor:pointer;background:linear-gradient(135deg,var(--rose),var(--deep-rose));color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;text-decoration:none;box-shadow:0 8px 24px rgba(200,104,90,.36);transition:background 0.3s ease,box-shadow 0.3s ease,transform 0.22s ease;-webkit-tap-highlight-color:transparent}
.watch-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(200,104,90,.46)}
.share-img-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:13px 18px;border:1.5px solid rgba(43,24,16,.15);border-radius:12px;background:rgba(255,255,255,.7);backdrop-filter:blur(8px);color:var(--ink);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.22s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.share-img-btn:hover{border-color:var(--rose);color:var(--rose);transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,104,90,.15)}
.share-img-btn.loading{opacity:.6;pointer-events:none}
.another-link{display:block;text-align:center;font-size:15px;font-weight:500;color:var(--rose);cursor:pointer;padding:10px 4px;transition:all 0.18s;-webkit-tap-highlight-color:transparent;letter-spacing:.01em}
.another-link:hover{color:var(--deep-rose);transform:translateX(3px)}
.divider{height:1px;background:linear-gradient(to right,transparent,rgba(43,24,16,.1),transparent);margin:14px 0}
.restart-btn{background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;transition:color 0.18s;-webkit-tap-highlight-color:transparent}
.restart-btn:hover{color:var(--ink)}
#share-overlay{display:none;position:fixed;inset:0;background:rgba(43,24,16,.6);backdrop-filter:blur(5px);z-index:100;align-items:center;justify-content:center;padding:20px}
#share-overlay.show{display:flex}
.share-modal{background:var(--card);border-radius:22px;padding:24px;max-width:330px;width:100%;animation:riseIn 0.38s cubic-bezier(.16,1,.3,1)}
#share-card{border-radius:14px;padding:22px;margin-bottom:18px;background:linear-gradient(145deg,#2B1810 0%,#5A2E20 100%);color:#fff;position:relative;overflow:hidden}
#share-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(200,164,94,.28),transparent 60%);pointer-events:none}
.sc-app{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:12px}
.sc-title{font-family:'Playfair Display',serif;font-size:19px;margin-bottom:7px}
.sc-vibe{font-size:12px;color:rgba(255,255,255,.68);line-height:1.55;margin-bottom:16px;font-style:italic}
.sc-meta{font-size:11px;color:var(--gold);letter-spacing:.1em}
.share-actions{display:flex;gap:10px}
.sa-btn{flex:1;padding:12px 10px;border-radius:10px;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;transition:all 0.18s;-webkit-tap-highlight-color:transparent}
.sa-btn.primary{background:var(--ink);color:#fff}
.sa-btn.secondary{background:rgba(43,24,16,.07);color:var(--ink)}
.sa-btn:hover{transform:translateY(-1px)}
#toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;padding:12px 24px;border-radius:50px;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;transition:opacity 0.3s ease,transform 0.3s ease;pointer-events:none;z-index:200;white-space:nowrap}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#upcoming-dramas{position:relative;z-index:1;padding:56px 20px 72px;background:linear-gradient(to bottom,var(--cream) 0%,rgba(239,207,196,.18) 100%);border-top:1px solid rgba(43,24,16,.07)}
.upcoming-inner{max-width:1160px;margin:0 auto}
.upcoming-head{margin-bottom:32px}
.upcoming-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.upcoming-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulsate 2.2s ease-in-out infinite}
#upcoming-heading{font-family:'Playfair Display',serif;font-size:clamp(26px,4vw,38px);color:var(--ink);line-height:1.15;margin-bottom:8px}
.upcoming-sub{font-size:14px;color:var(--muted);max-width:480px}
#upcoming-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
#upcoming-grid:empty::after{content:'No upcoming dramas right now \2014  check back soon.';font-size:14px;color:var(--muted);grid-column:1/-1;padding:16px 0}
.upcoming-card{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px rgba(43,24,16,.07);border:1px solid rgba(43,24,16,.06);display:flex;flex-direction:column;transition:transform 0.22s cubic-bezier(.34,1.56,.64,1),box-shadow 0.22s ease}
.upcoming-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(43,24,16,.13)}
.upc-poster{position:relative;aspect-ratio:2/3;background:linear-gradient(145deg,var(--blush),rgba(200,104,90,.3));overflow:hidden;flex-shrink:0;max-height:220px}
.upc-poster img{width:100%;height:100%;object-fit:cover;display:block}
.upc-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px}
.upc-countdown{position:absolute;bottom:8px;left:8px;right:8px;background:rgba(43,24,16,.76);backdrop-filter:blur(10px);border-radius:8px;padding:5px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px}
.upc-countdown-label{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.upc-countdown-days{font-family:'Playfair Display',serif;font-size:15px;color:#fff;font-weight:600}
.upc-body{padding:14px;display:flex;flex-direction:column;gap:7px;flex:1}
.upc-title{font-family:'Playfair Display',serif;font-size:14px;color:var(--ink);line-height:1.25;font-weight:600}
.upc-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.upc-platform{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--rose)}
.upc-date{font-size:10px;color:var(--muted);display:flex;align-items:center;gap:4px}
.upc-date svg{flex-shrink:0;opacity:.6}
.upc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}
.upc-tag{padding:2px 8px;border-radius:50px;background:rgba(200,104,90,.09);color:var(--rose);font-size:9.5px;font-weight:500}
.upc-watch{display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding:6px 12px;font-size:11px;font-weight:500;color:#fff;text-decoration:none;border-radius:6px;background:var(--rose);transition:opacity 0.18s}
.upc-watch:hover{opacity:0.85}
.upc-skel-card{height:300px;border-radius:16px;background:linear-gradient(90deg,rgba(43,24,16,.06) 25%,rgba(43,24,16,.1) 50%,rgba(43,24,16,.06) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}
@media(max-width:1024px){
#upcoming-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:640px){
#site-header{padding:12px 16px}
#logo-tagline{display:none}
#app{padding:20px 14px 36px}
.result-layout{grid-template-columns:110px 1fr;gap:12px;padding:12px}
.drama-title{font-size:15px}
#alt-cards{grid-template-columns:1fr}
#dv-card{grid-template-columns:72px 1fr}
#upcoming-dramas{padding:40px 0 48px}
.upcoming-head{padding:0 16px}
#upcoming-grid{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding:4px 16px 16px;scrollbar-width:none;-ms-overflow-style:none}
#upcoming-grid::-webkit-scrollbar{display:none}
.upcoming-card{flex:0 0 220px;scroll-snap-align:start}
.upc-poster{max-height:180px}
.upc-skel-card{flex:0 0 220px;height:260px}
}
@media(max-height:640px){#app{align-items:flex-start;padding-top:20px}}
