/* ============================================================
   CINEMERE CORE — shared design system + social components
   Loaded by every page. Page-specific CSS stays in-page.
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --void:#04021A;--deep:#080424;--cosmos:#0E073A;--dusk:#1A0C48;
  --burnt:#9B3018;--ember:#D05418;--fire:#E87820;--horizon:#F5A030;
  --amber:#FFD060;--cream:#FFF2D8;
  --electric:#00D4FF;--magenta:#E080CC;--green:#80D4A0;
  --text:#FFF0E0;--text2:#D4AC80;--text3:#AC8B61;--text4:#846A45;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Syne',system-ui,sans-serif;
  --mono:'Syne Mono',monospace;
  --r:10px;--r2:18px;--r3:28px;
  --border:rgba(255,200,80,0.07);--border2:rgba(255,200,80,0.14)
}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none;min-height:100vh}
a,button{cursor:none;text-decoration:none;color:inherit}
img{display:block}
::selection{background:rgba(255,208,96,0.25);color:var(--cream)}

/* GRAIN */
body::after{content:'';position:fixed;inset:0;opacity:.026;pointer-events:none;z-index:9998;mix-blend-mode:overlay;
  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.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* CURSOR (shared) */
#mq-cur{position:fixed;width:16px;height:16px;border:1.5px solid var(--amber);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .15s,height .15s,border-color .2s;mix-blend-mode:difference}
#mq-cur.big{width:34px;height:34px;border-color:rgba(255,208,96,.5)}
#mq-curd{position:fixed;width:4px;height:4px;background:var(--amber);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%)}
@media(hover:none){#mq-cur,#mq-curd{display:none}body{cursor:auto}a,button{cursor:pointer}}

/* ============================ NAV ============================ */
#mq-nav{position:fixed;top:0;left:0;right:0;z-index:700;height:60px;display:flex;align-items:center;gap:22px;padding:0 32px;background:rgba(4,2,26,.9);backdrop-filter:blur(22px);border-bottom:1px solid var(--border)}
.mqn-logo{font-family:var(--serif);font-size:16px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;background:linear-gradient(135deg,var(--amber),var(--horizon));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex-shrink:0}
.mqn-links{display:flex;gap:4px;align-items:center}
.mqn-link{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);padding:8px 13px;border-radius:999px;transition:all .2s;position:relative;white-space:nowrap}
.mqn-link:hover{color:var(--cream);background:rgba(255,255,255,.04)}
.mqn-link.on{color:var(--amber)}
.mqn-link.on::after{content:'';position:absolute;left:13px;right:13px;bottom:2px;height:1px;background:linear-gradient(90deg,transparent,var(--amber),transparent)}
.mqn-spring{flex:1}
.mqn-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.mqn-bell{position:relative;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;border:1px solid var(--border);background:rgba(255,255,255,.03);transition:all .2s;color:var(--text2)}
.mqn-bell:hover{border-color:var(--border2);color:var(--cream)}
.mqn-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:linear-gradient(135deg,var(--ember),var(--horizon));color:var(--void);font-family:var(--mono);font-size:9px;font-weight:700;display:none;align-items:center;justify-content:center;border:1.5px solid var(--void)}
.mqn-badge.show{display:flex}
.mqn-av{width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,208,96,.35);background:linear-gradient(135deg,var(--burnt),var(--horizon));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;font-weight:700;color:var(--void);overflow:hidden;flex-shrink:0}
.mqn-av img{width:100%;height:100%;object-fit:cover}
.mqn-signin{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--void);background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));padding:10px 22px;border-radius:999px;transition:all .25s}
.mqn-signin:hover{box-shadow:0 10px 30px rgba(245,160,48,.4);transform:translateY(-1px)}
.mqn-menu{position:fixed;top:56px;right:24px;z-index:760;background:linear-gradient(135deg,#0E0828,#16092C);border:1px solid var(--border2);border-radius:14px;padding:8px;min-width:200px;box-shadow:0 30px 70px rgba(0,0,0,.7);display:none;flex-direction:column;gap:2px}
.mqn-menu.show{display:flex}
.mqn-mi{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;font-size:13px;color:var(--text2);transition:all .18s;background:none;border:none;text-align:left;width:100%}
.mqn-mi:hover{background:rgba(255,200,80,.07);color:var(--cream)}
.mqn-mi.sep{border-top:1px solid var(--border);border-radius:0;margin-top:4px;padding-top:12px}
.mqn-mhead{padding:12px 12px 10px;border-bottom:1px solid var(--border);margin-bottom:4px}
.mqn-mname{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--cream);line-height:1}
.mqn-mhandle{font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:4px;letter-spacing:.05em}
@media(max-width:780px){
  #mq-nav{gap:10px;padding:0 16px}
  .mqn-links{gap:0;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
  .mqn-links::-webkit-scrollbar{display:none}
  .mqn-link{padding:8px 9px;font-size:10px}
}

/* page top spacer so fixed nav doesn't overlap */
.mq-pad{height:60px}

/* ============================ BUTTONS ============================ */
.mq-btn{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:12px 26px;border-radius:999px;border:none;transition:all .25s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.mq-fire{background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));color:var(--void)}
.mq-fire:hover{box-shadow:0 14px 40px rgba(245,160,48,.5);transform:translateY(-2px)}
.mq-ghost{background:rgba(255,255,255,.05);border:1px solid var(--border2);color:var(--text2)}
.mq-ghost:hover{border-color:rgba(255,200,80,.4);color:var(--cream)}
.mq-el{background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.28);color:var(--electric)}
.mq-el:hover{background:rgba(0,212,255,.16);border-color:rgba(0,212,255,.5)}

/* avatar helper */
.mq-av{border-radius:50%;background:linear-gradient(135deg,#1A0830,#2C1848);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;color:var(--horizon);overflow:hidden;flex-shrink:0;border:1px solid rgba(255,200,80,.12)}
.mq-av img{width:100%;height:100%;object-fit:cover}

/* ============================ TOAST ============================ */
#mq-toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(14px);background:rgba(12,6,32,.97);border:1px solid rgba(255,200,80,.24);border-radius:999px;padding:12px 26px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--amber);z-index:99990;opacity:0;transition:transform .3s,opacity .3s;pointer-events:none;backdrop-filter:blur(16px);white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}
#mq-toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ============================ MINI QUICK VIEW ============================ */
#mq-qv{position:fixed;inset:0;z-index:9000;display:none;align-items:center;justify-content:center;padding:24px}
#mq-qv.show{display:flex}
.mqv-bg{position:absolute;inset:0;background:rgba(4,2,26,.9);backdrop-filter:blur(22px)}
.mqv-box{position:relative;z-index:2;background:linear-gradient(135deg,#0E0828,#18082C);border:1px solid rgba(255,200,80,.15);border-radius:24px;overflow:hidden;max-width:760px;width:100%;display:grid;grid-template-columns:230px 1fr;box-shadow:0 48px 100px rgba(0,0,0,.8);max-height:88vh}
.mqv-left{overflow:hidden;background:linear-gradient(135deg,#1A0830,#2C0820);display:flex;align-items:center;justify-content:center;font-size:60px}
.mqv-left img{width:100%;height:100%;object-fit:cover;min-height:340px}
.mqv-right{padding:30px 28px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}
.mqv-type{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--horizon)}
.mqv-title{font-family:var(--serif);font-size:clamp(24px,3vw,38px);font-weight:700;color:var(--cream);line-height:1.05}
.mqv-mrow{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.mqv-sc{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--amber)}
.mqv-m{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.06em}
.mqv-ov{font-family:var(--serif);font-size:15.5px;font-weight:400;line-height:1.68;color:rgba(255,228,196,.92)}
.mqv-genres{display:flex;gap:7px;flex-wrap:wrap}
.mqv-g{font-family:var(--mono);font-size:9px;letter-spacing:.09em;text-transform:uppercase;padding:4px 11px;border-radius:999px;border:1px solid rgba(255,200,80,.12);color:var(--text3);background:rgba(255,200,80,.03)}
.mqv-acts{display:flex;gap:9px;flex-wrap:wrap;margin-top:6px}
.mqv-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text2);font-size:14px;display:flex;align-items:center;justify-content:center;z-index:3;transition:all .2s}
.mqv-close:hover{background:rgba(255,200,80,.12);color:var(--cream)}
@media(max-width:760px){.mqv-box{grid-template-columns:1fr}.mqv-left{height:210px}.mqv-left img{min-height:210px}}

/* ----- POST DETAIL MODAL (polls, reactions, comments) ----- */
#mq-post{position:fixed;inset:0;z-index:9100;display:none;align-items:center;justify-content:center;padding:24px}
#mq-post.show{display:flex}
.mqpo-bg{position:absolute;inset:0;background:rgba(4,2,26,.9);backdrop-filter:blur(22px)}
.mqpo-box{position:relative;z-index:2;background:linear-gradient(150deg,#0E0828,#18082C);border:1px solid rgba(255,200,80,.15);border-radius:22px;width:100%;max-width:560px;max-height:88vh;overflow-y:auto;box-shadow:0 48px 100px rgba(0,0,0,.8)}
.mqpo-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text2);font-size:14px;display:flex;align-items:center;justify-content:center;z-index:3;transition:all .2s}
.mqpo-close:hover{background:rgba(255,200,80,.12);color:var(--cream)}
.mqpo-body{padding:26px}
.mqpo-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-right:30px}
.mqpo-h-info{flex:1;min-width:0}
.mqpo-h-nm{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--cream);text-decoration:none}
.mqpo-h-nm:hover{color:var(--amber)}
.mqpo-h-sub{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.05em;margin-top:2px}
.mqpo-badge{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:6px 11px;border-radius:999px;border:1px solid var(--border2);color:var(--text2);background:rgba(255,255,255,.03);flex-shrink:0;align-self:flex-start}
.mqpo-badge.mqpo-poll{color:var(--electric);border-color:rgba(0,212,255,.3)}
.mqpo-badge.mqpo-take{color:var(--amber);border-color:rgba(255,208,96,.3)}
.mqpo-badge.mqpo-watching{color:var(--green);border-color:rgba(128,212,160,.3)}
.mqpo-badge.mqpo-list{color:var(--magenta);border-color:rgba(224,128,204,.3)}
.mqpo-stars{color:var(--amber);font-size:18px;margin-bottom:10px}
.mqpo-text{font-family:var(--serif);font-size:20px;font-weight:300;line-height:1.5;color:var(--text);margin-bottom:16px}
.mqpo-poll{display:flex;flex-direction:column;gap:9px;margin-bottom:16px}
.mqpo-opt{position:relative;display:block;width:100%;text-align:left;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:rgba(255,255,255,.02);transition:border-color .2s;padding:0;cursor:none}
.mqpo-opt:hover{border-color:var(--border2)}
.mqpo-opt.voted{border-color:rgba(255,208,96,.4)}
.mqpo-optbar{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(245,160,48,.18),rgba(245,160,48,.05));transition:width .6s ease}
.mqpo-opt.win .mqpo-optbar{background:linear-gradient(90deg,rgba(245,160,48,.3),rgba(255,208,96,.1))}
.mqpo-optrow{position:relative;display:flex;align-items:center;gap:11px;padding:10px 12px}
.mqpo-optposter{width:34px;height:51px;border-radius:6px;overflow:hidden;background:#1A0830;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px}
.mqpo-optposter img{width:100%;height:100%;object-fit:cover}
.mqpo-optname{flex:1;font-size:15px;color:var(--cream);font-weight:600}
.mqpo-check{font-family:var(--mono);font-size:9px;color:var(--amber);letter-spacing:.06em;margin-left:5px}
.mqpo-optpct{font-family:var(--mono);font-size:13px;color:var(--amber);font-weight:700}
.mqpo-voters{position:relative;display:flex;align-items:center;padding:0 12px 10px 57px;flex-wrap:wrap;min-height:8px}
.mqpo-voters .mq-av{margin-right:-6px;border:1.5px solid #0E0828}
.mqpo-vmore{font-family:var(--mono);font-size:9px;color:var(--text3);margin-left:11px}
.mqpo-pollmeta{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.05em;margin-top:2px}
.mqpo-titles{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.mqpo-reacts{display:flex;gap:8px;padding:14px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.mqpo-react{font-size:15px;padding:7px 13px;border-radius:999px;border:1px solid var(--border2);background:rgba(255,255,255,.03);color:var(--text2);transition:all .2s;display:inline-flex;align-items:center;gap:5px;cursor:none}
.mqpo-react:hover{border-color:rgba(255,200,80,.4)}
.mqpo-react.on{background:rgba(255,208,96,.14);border-color:rgba(255,208,96,.45)}
.mqpo-react b{font-size:11px;color:var(--amber);font-weight:700}
.mqpo-cmts{display:flex;flex-direction:column;gap:13px;margin-top:16px}
.mqpo-cmt{display:flex;gap:10px}
.mqpo-cmt-b{flex:1;min-width:0}
.mqpo-cmt-h b{color:var(--cream);font-weight:600;font-size:12px}
.mqpo-cmt-h span{font-family:var(--mono);font-size:9px;color:var(--text3);margin-left:6px}
.mqpo-cmt-tx{font-size:14px;color:var(--text);line-height:1.5;margin-top:3px;word-wrap:break-word}
.mqpo-nocmt{font-family:var(--serif);font-style:italic;color:var(--text3);padding:8px 0}
.mqpo-cmtform{display:flex;align-items:center;gap:9px;margin-top:16px}
.mqpo-cmt-in{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:999px;padding:10px 15px;font-family:var(--sans);font-size:13px;color:var(--text);outline:none;transition:border-color .2s;cursor:none}
.mqpo-cmt-in:focus{border-color:var(--border2)}
.mqpo-cmt-send{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--void);background:linear-gradient(135deg,var(--ember),var(--horizon));border:none;border-radius:999px;padding:10px 16px;cursor:none}
.mqpo-signin{display:block;text-align:center;margin-top:16px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--horizon);text-decoration:none;padding:12px;border:1px solid var(--border2);border-radius:12px}
.mqpo-gone{font-family:var(--serif);font-style:italic;color:var(--text3);text-align:center;padding:40px 0}

/* ----- PROFILE STUDIO (settings: identity, picture, cover, services) ----- */
#mq-set{position:fixed;inset:0;z-index:9200;display:none;align-items:center;justify-content:center;padding:24px}
#mq-set.show{display:flex}
.mqs-bg{position:absolute;inset:0;background:rgba(4,2,26,.92);backdrop-filter:blur(24px)}
.mqs-box{position:relative;z-index:2;width:100%;max-width:620px;max-height:90vh;display:flex;flex-direction:column;background:linear-gradient(160deg,#0E0828,#16092C);border:1px solid rgba(255,200,80,.16);border-radius:24px;overflow:hidden;box-shadow:0 50px 110px rgba(0,0,0,.85)}
.mqs-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:rgba(4,2,26,.6);border:1px solid rgba(255,255,255,.14);color:var(--cream);font-size:14px;z-index:6;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:none}
.mqs-close:hover{background:rgba(255,200,80,.18)}
/* live preview */
.mqs-preview{position:relative;flex-shrink:0}
.mqs-pv-cover{height:132px;background:linear-gradient(170deg,#1C0D48 0%,#5A1A28 35%,#CC5015 60%,#F5A030 78%,#7A2810 100%);background-size:cover;background-position:center top;background-repeat:no-repeat;position:relative}
.mqs-pv-fog{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,8,40,.96),rgba(14,8,40,.2) 60%,transparent),radial-gradient(ellipse 50% 60% at 50% 0%,rgba(255,200,80,.08),transparent 70%)}
.mqs-pv-row{position:relative;display:flex;align-items:flex-end;gap:14px;padding:0 24px 16px;margin-top:-36px}
.mqs-pv-av{width:74px;height:74px;border-radius:50%;border:3px solid var(--horizon);overflow:hidden;background:linear-gradient(135deg,#1A0830,#2C1048);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 12px 34px rgba(0,0,0,.65)}
.mqs-pv-av img{width:100%;height:100%;object-fit:cover}
.mqs-pv-nm{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--cream);line-height:1.1}
.mqs-pv-hd{font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:4px;letter-spacing:.04em}
/* section tabs */
.mqs-nav{display:flex;gap:2px;padding:6px 18px 0;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}
.mqs-tab{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);background:none;border:none;padding:12px 14px;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;cursor:none}
.mqs-tab:hover{color:var(--text2)}
.mqs-tab.on{color:var(--amber);border-bottom-color:var(--horizon)}
/* body */
.mqs-body{flex:1;min-height:0;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:18px}
.mqs-field{display:flex;flex-direction:column;gap:9px}
.mqs-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.mqs-in,.mqs-ta{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;padding:11px 14px;font-family:var(--sans);font-size:14px;color:var(--text);outline:none;transition:border-color .2s;width:100%;cursor:none}
.mqs-ta{font-family:var(--serif);font-size:15px;font-weight:300;resize:none;line-height:1.55}
.mqs-in::placeholder,.mqs-ta::placeholder{color:var(--text3)}
.mqs-in:focus,.mqs-ta:focus{border-color:var(--border2)}
.mqs-colors{display:flex;gap:10px;flex-wrap:wrap}
.mqs-color{width:30px;height:30px;border-radius:50%;border:2px solid transparent;transition:transform .15s,border-color .15s;box-shadow:inset 0 0 0 2px rgba(4,2,26,.5);cursor:none}
.mqs-color:hover{transform:scale(1.12)}
.mqs-color.on{border-color:var(--cream);transform:scale(1.14)}
.mqs-tags{display:flex;flex-wrap:wrap;gap:7px;min-height:8px}
.mqs-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;padding:6px 11px;border-radius:999px;border:1px solid var(--border2);color:var(--text2);background:rgba(255,255,255,.03)}
.mqs-tag b{color:var(--text3);font-weight:700;cursor:none}.mqs-tag b:hover{color:var(--ember)}
.mqs-tag-empty{font-family:var(--serif);font-style:italic;color:var(--text3);font-size:13px}
.mqs-tagadd{display:flex;gap:8px}
.mqs-tagbtn{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--text2);background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:10px;padding:0 16px;cursor:none}
.mqs-tagbtn:hover{color:var(--cream)}
.mqs-modes{display:flex;gap:4px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:999px;padding:4px;align-self:flex-start}
.mqs-mode{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);background:none;border:none;padding:8px 18px;border-radius:999px;cursor:none}
.mqs-mode.on{background:rgba(255,208,96,.14);color:var(--amber)}
.mqs-pick-note,.mqs-mono-note{font-family:var(--mono);font-size:10px;line-height:1.65;letter-spacing:.02em;color:var(--text2);background:rgba(0,212,255,.05);border:1px solid rgba(0,212,255,.16);border-radius:10px;padding:11px 13px}
.mqs-pick-note b{color:var(--electric)}
.mqs-mono-note{background:rgba(255,208,96,.05);border-color:rgba(255,208,96,.16)}
.mqs-mono-note b{color:var(--amber)}
.mqs-hint{font-family:var(--serif);font-style:italic;color:var(--text3);font-size:13px;text-align:center;padding:14px 0}
.mqs-grid{display:grid;gap:10px}
.mqs-pgrid{grid-template-columns:repeat(auto-fill,minmax(76px,1fr))}
.mqs-cgrid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.mqs-pcard{position:relative;border-radius:10px;overflow:hidden;border:2px solid transparent;background:#1A0830;padding:0;aspect-ratio:2/3;transition:border-color .2s,transform .2s;cursor:none}
.mqs-pcard.wide{aspect-ratio:16/9}
.mqs-pcard:hover{transform:translateY(-2px)}
.mqs-pcard img{width:100%;height:100%;object-fit:cover;display:block}
.mqs-pcard.on{border-color:var(--amber)}
.mqs-pcap{position:absolute;left:0;right:0;bottom:0;padding:7px 8px;font-family:var(--sans);font-size:9px;font-weight:600;color:var(--cream);background:linear-gradient(to top,rgba(4,2,26,.94),transparent);text-align:left;line-height:1.2;opacity:0;transition:opacity .2s}
.mqs-pcard:hover .mqs-pcap{opacity:1}
.mqs-pcheck{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--horizon);color:var(--void);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;opacity:0;transform:scale(.6);transition:all .2s}
.mqs-pcard.on .mqs-pcheck{opacity:1;transform:scale(1)}
.mqs-reset{align-self:flex-start;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);background:none;border:1px solid var(--border);border-radius:999px;padding:9px 16px;transition:all .2s;cursor:none}
.mqs-reset:hover{border-color:var(--border2);color:var(--text2)}
.mqs-svcs{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.mqs-svc{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.02);transition:all .2s;text-align:left;cursor:none}
.mqs-svc:hover{border-color:var(--border2)}
.mqs-svc.on{border-color:rgba(128,212,160,.4);background:rgba(128,212,160,.06)}
.mqs-svc-dot{width:8px;height:8px;border-radius:50%;background:var(--text4);flex-shrink:0;transition:all .2s}
.mqs-svc.on .mqs-svc-dot{background:var(--green);box-shadow:0 0 8px var(--green)}
.mqs-svc-nm{flex:1;font-size:13px;font-weight:600;color:var(--cream)}
.mqs-svc-tg{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3)}
.mqs-svc.on .mqs-svc-tg{color:var(--green)}
.mqs-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 22px;border-top:1px solid var(--border);background:rgba(4,2,26,.45);flex-shrink:0}
.mqs-lock{font-family:var(--mono);font-size:9px;letter-spacing:.03em;color:var(--text3);display:flex;align-items:center;gap:5px}
.mqs-foot-btns{display:flex;gap:9px}
.mqs-cancel{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--text2);background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:999px;padding:11px 20px;cursor:none}
.mqs-cancel:hover{color:var(--cream)}
.mqs-save{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--void);background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));border:none;border-radius:999px;padding:11px 24px;cursor:none}
.mqs-save:hover{box-shadow:0 10px 30px rgba(245,160,48,.45)}
@media(max-width:560px){ .mqs-svcs{grid-template-columns:1fr} .mqs-cgrid{grid-template-columns:1fr 1fr} .mqs-box{max-height:94vh} }

/* ----- EXPANDABLE NAV SEARCH — a glass that blooms into a Browse-style pill ----- */
.mqn-search{display:flex;align-items:center;width:40px;height:40px;border-radius:999px;border:1px solid transparent;background:transparent;overflow:visible;flex-shrink:0;transition:width .42s cubic-bezier(.4,0,.2,1),background .3s,border-color .3s,box-shadow .3s}
.mqn-search.open{width:clamp(240px,40vw,520px);background:rgba(255,255,255,.05);border-color:var(--border2);box-shadow:0 0 0 3px rgba(245,160,48,.06)}
/* the search jewel — a gradient glass with a rotating golden aura + breathing halo */
.mqn-sbtn{position:relative;flex:0 0 40px;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;padding:0;cursor:none;overflow:visible;
  background:radial-gradient(circle at 34% 28%, #211450, #0a0524 78%);
  box-shadow:0 0 0 1px rgba(255,200,80,.16), inset 0 1px 1px rgba(255,255,255,.06), 0 5px 16px rgba(0,0,0,.45);
  transition:transform .4s cubic-bezier(.34,1.56,.64,1), box-shadow .4s}
.mqn-sbtn .mqn-glass{width:22px;height:22px;position:relative;z-index:2;overflow:visible;transition:transform .45s cubic-bezier(.34,1.56,.64,1)}
.mqn-sbtn::before{content:'';position:absolute;inset:-3px;border-radius:50%;z-index:1;pointer-events:none;
  background:conic-gradient(from 0deg, transparent 0%, rgba(245,160,48,0) 10%, var(--amber) 36%, var(--horizon) 54%, var(--ember) 70%, transparent 88%);
  -webkit-mask:radial-gradient(circle, transparent 55%, #000 59%); mask:radial-gradient(circle, transparent 55%, #000 59%);
  opacity:.6;filter:blur(.5px);animation:mqg-spin 6s linear infinite;transition:opacity .4s}
.mqn-sbtn::after{content:'';position:absolute;inset:0;border-radius:50%;z-index:0;pointer-events:none;animation:mqg-breathe 3.6s ease-in-out infinite}
.mqn-sbtn:hover{transform:scale(1.1);box-shadow:0 0 0 1px rgba(255,214,120,.55), 0 0 30px rgba(245,160,48,.5), inset 0 1px 2px rgba(255,255,255,.14)}
.mqn-sbtn:hover::before{opacity:1;animation-duration:2.4s}
.mqn-sbtn:hover .mqn-glass{transform:rotate(-14deg) scale(1.06)}
.mqn-sbtn:active{transform:scale(1.02)}
.mqg-fill{transition:opacity .4s}
.mqg-glint{transform-origin:center;animation:mqg-twinkle 3.6s ease-in-out infinite}
@keyframes mqg-spin{to{transform:rotate(360deg)}}
@keyframes mqg-breathe{0%,100%{box-shadow:0 0 9px 0 rgba(245,160,48,.12)}50%{box-shadow:0 0 20px 3px rgba(245,160,48,.30)}}
@keyframes mqg-twinkle{0%,100%{opacity:.25;transform:scale(.78)}50%{opacity:.95;transform:scale(1.12)}}
@media (prefers-reduced-motion: reduce){ .mqn-sbtn::before,.mqn-sbtn::after,.mqg-glint{animation:none} }
/* open state — the jewel calms into a plain in-pill icon */
.mqn-search.open .mqn-sbtn{background:transparent;box-shadow:none;transform:none}
.mqn-search.open .mqn-sbtn::before,.mqn-search.open .mqn-sbtn::after{opacity:0;animation:none}
.mqn-search.open .mqn-glass{transform:none}
.mqn-sinput{flex:1;min-width:0;background:none;border:none;outline:none;font-family:var(--sans);font-size:13px;color:var(--text);padding:0 8px;opacity:0;transition:opacity .25s .08s;cursor:none}
.mqn-search.open .mqn-sinput{opacity:1}
.mqn-sinput::placeholder{color:var(--text3)}
.mqn-sclear{flex:0 0 auto;width:26px;height:26px;margin-right:6px;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:11px;color:var(--text3);background:rgba(255,255,255,.06);border:none;transition:all .2s;cursor:none}
.mqn-search.open .mqn-sclear{display:flex}
.mqn-sclear:hover{color:var(--cream);background:rgba(255,200,80,.14)}
.mqn-drop{position:fixed;top:64px;z-index:699;background:linear-gradient(160deg,#0E0828,#16092C);border:1px solid var(--border2);border-radius:16px;box-shadow:0 40px 100px rgba(0,0,0,.7);overflow:hidden;opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .25s,transform .25s}
.mqn-drop.show{opacity:1;transform:translateY(0);pointer-events:auto}
.mqn-drop .mqk-results{max-height:62vh;overflow-y:auto;padding:8px}
@media(max-width:780px){ .mqn-search.open{width:min(72vw,360px)} }

/* ----- ⌘K UNIVERSAL SEARCH (command-palette fallback) ----- */
#mq-ks{position:fixed;inset:0;z-index:9300;display:none;align-items:flex-start;justify-content:center;padding:13vh 24px 24px}
#mq-ks.show{display:flex}
.mqk-bg{position:absolute;inset:0;background:rgba(4,2,26,.86);backdrop-filter:blur(20px)}
.mqk-box{position:relative;z-index:2;width:100%;max-width:600px;background:linear-gradient(160deg,#0E0828,#16092C);border:1px solid rgba(255,200,80,.18);border-radius:18px;overflow:hidden;box-shadow:0 50px 120px rgba(0,0,0,.85)}
.mqk-inputwrap{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border)}
.mqk-ico{font-size:18px;color:var(--horizon)}
.mqk-input{flex:1;background:none;border:none;outline:none;font-family:var(--sans);font-size:17px;color:var(--text);cursor:none}
.mqk-input::placeholder{color:var(--text3)}
.mqk-esc{font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--text3);border:1px solid var(--border2);border-radius:6px;padding:4px 7px}
.mqk-results{max-height:54vh;overflow-y:auto;padding:8px}
.mqk-hint{font-family:var(--serif);font-style:italic;color:var(--text3);text-align:center;padding:28px 0;font-size:14px}
.mqk-group{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);padding:12px 12px 6px}
.mqk-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:9px 12px;border-radius:11px;border:1px solid transparent;background:none;transition:background .12s,border-color .12s;cursor:none}
.mqk-row.on{background:rgba(255,208,96,.1);border-color:rgba(255,208,96,.25)}
.mqk-pos{width:34px;height:50px;border-radius:6px;overflow:hidden;background:#1A0830;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px}
.mqk-pos.round{width:38px;height:38px;border-radius:50%}
.mqk-pos img{width:100%;height:100%;object-fit:cover}
.mqk-info{flex:1;min-width:0}
.mqk-nm{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--cream);line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mqk-sub{font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:2px;letter-spacing:.04em}
.mqk-kind{font-family:var(--mono);font-size:9px;letter-spacing:.06em;color:var(--text3);flex-shrink:0}
.mqk-row.on .mqk-kind{color:var(--amber)}
@media(max-width:560px){ #mq-ks{padding:8vh 12px 12px} }

/* ----- LIST EDITOR (create / edit a curated list) ----- */
#mq-le{position:fixed;inset:0;z-index:9250;display:none;align-items:center;justify-content:center;padding:24px}
#mq-le.show{display:flex}
.mqle-bg{position:absolute;inset:0;background:rgba(4,2,26,.92);backdrop-filter:blur(24px)}
.mqle-box{position:relative;z-index:2;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;background:linear-gradient(160deg,#0E0828,#16092C);border:1px solid rgba(255,200,80,.16);border-radius:22px;overflow:hidden;box-shadow:0 50px 110px rgba(0,0,0,.85)}
.mqle-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:rgba(4,2,26,.6);border:1px solid rgba(255,255,255,.14);color:var(--cream);font-size:14px;z-index:5;display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:none}
.mqle-close:hover{background:rgba(255,200,80,.18)}
.mqle-body{flex:1;min-height:0;overflow-y:auto;padding:24px 22px;display:flex;flex-direction:column;gap:13px}
.mqle-h{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--cream);padding-right:30px}
.mqle-name{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-family:var(--serif);font-size:18px;font-weight:700;color:var(--cream);outline:none;transition:border-color .2s;cursor:none}
.mqle-name:focus{border-color:var(--border2)}
.mqle-desc{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;padding:11px 14px;font-family:var(--serif);font-size:14px;font-weight:300;color:var(--text);outline:none;resize:none;line-height:1.5;cursor:none}
.mqle-desc:focus{border-color:var(--border2)}
.mqle-name::placeholder,.mqle-desc::placeholder{color:var(--text3);font-weight:400}
.mqle-rank{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--text2)}
.mqle-rank input{accent-color:var(--amber);width:15px;height:15px}
.mqle-titlesh{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.mqle-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.mqle-add{font-family:var(--sans);font-size:11px;font-weight:700;color:var(--void);background:linear-gradient(135deg,var(--ember),var(--horizon));border:none;border-radius:999px;padding:8px 15px;cursor:none}
.mqle-add:hover{box-shadow:0 8px 20px rgba(245,160,48,.4)}
.mqle-titles{display:flex;flex-direction:column;gap:8px}
.mqle-empty{font-family:var(--serif);font-style:italic;color:var(--text3);text-align:center;padding:22px 0;border:1px dashed var(--border2);border-radius:12px;font-size:14px}
.mqle-row{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.02)}
.mqle-rk{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--horizon);width:22px;text-align:center;flex-shrink:0}
.mqle-pos{width:32px;height:48px;border-radius:5px;overflow:hidden;background:#1A0830;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}
.mqle-pos img{width:100%;height:100%;object-fit:cover}
.mqle-tnm{flex:1;font-size:14px;font-weight:600;color:var(--cream);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mqle-tnm span{font-family:var(--mono);font-size:10px;color:var(--text3);font-weight:400}
.mqle-acts{display:flex;gap:4px;flex-shrink:0}
.mqle-acts button{width:26px;height:26px;border-radius:7px;background:rgba(255,255,255,.04);border:1px solid var(--border2);color:var(--text2);font-size:11px;cursor:none;transition:all .2s}
.mqle-acts button:hover:not(:disabled){border-color:rgba(255,200,80,.4);color:var(--cream)}
.mqle-acts button:disabled{opacity:.3}
.mqle-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 22px;border-top:1px solid var(--border);background:rgba(4,2,26,.45)}
.mqle-count{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.05em}
.mqle-cancel{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--text2);background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:999px;padding:11px 20px;cursor:none}
.mqle-cancel:hover{color:var(--cream)}
.mqle-save{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--void);background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));border:none;border-radius:999px;padding:11px 24px;cursor:none}
.mqle-save:hover{box-shadow:0 10px 30px rgba(245,160,48,.45)}

/* ============================ TITLE PICKER ============================ */
#mq-picker{position:fixed;inset:0;z-index:9500;display:none;align-items:center;justify-content:center;padding:24px}
#mq-picker.show{display:flex}
.mqp-bg{position:absolute;inset:0;background:rgba(4,2,26,.92);backdrop-filter:blur(22px)}
.mqp-box{position:relative;z-index:2;background:linear-gradient(135deg,#0E0828,#18082C);border:1px solid rgba(255,200,80,.15);border-radius:24px;width:100%;max-width:720px;max-height:86vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 48px 100px rgba(0,0,0,.8)}
.mqp-head{padding:24px 28px 16px;border-bottom:1px solid var(--border);position:relative}
.mqp-title{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--cream);margin-bottom:3px}
.mqp-sub{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.08em}
.mqp-input{width:100%;margin-top:14px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:999px;padding:11px 18px;font-family:var(--sans);font-size:13px;color:var(--text);outline:none;transition:all .2s}
.mqp-input:focus{border-color:var(--border2);background:rgba(255,255,255,.07)}
.mqp-input::placeholder{color:var(--text3)}
.mqp-body{padding:18px 28px 24px;overflow-y:auto}
.mqp-hint{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--text3);padding:18px 0;text-align:center}
.mqp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:12px}
.mqp-item{transition:transform .2s}
.mqp-item:hover{transform:translateY(-3px)}
.mqp-poster{width:100%;aspect-ratio:2/3;border-radius:8px;overflow:hidden;background:linear-gradient(145deg,#1A0830,#2C0820);border:1px solid rgba(255,200,80,.08);display:flex;align-items:center;justify-content:center;font-size:24px;position:relative}
.mqp-item:hover .mqp-poster{border-color:rgba(255,200,80,.3)}
.mqp-poster img{width:100%;height:100%;object-fit:cover}
.mqp-name{font-family:var(--sans);font-size:10px;color:var(--text2);margin-top:5px;line-height:1.25;text-align:center;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.mqp-close{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text2);font-size:14px;display:flex;align-items:center;justify-content:center;z-index:3;transition:all .2s}
.mqp-close:hover{background:rgba(255,200,80,.12);color:var(--cream)}

/* ============================ ATTACHED TITLE CARD (in posts/messages) ============================ */
.mq-tcard{display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:12px;padding:9px;transition:all .2s;max-width:340px}
.mq-tcard:hover{border-color:var(--border2);background:rgba(255,200,80,.04)}
.mq-tcard-poster{width:46px;height:69px;border-radius:7px;overflow:hidden;flex-shrink:0;background:linear-gradient(145deg,#1A0830,#2C0820);display:flex;align-items:center;justify-content:center;font-size:18px}
.mq-tcard-poster img{width:100%;height:100%;object-fit:cover}
.mq-tcard-info{flex:1;min-width:0}
.mq-tcard-name{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--cream);line-height:1.15;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.mq-tcard-meta{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.06em;margin-top:3px}
.mq-tcard-x{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text3);font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mq-tcard-x:hover{color:var(--cream);border-color:var(--border2)}

/* reaction set (shared) */
.mq-reacts{display:flex;gap:6px;flex-wrap:wrap}
.mq-react{display:inline-flex;align-items:center;gap:5px;padding:6px 11px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.025);font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--text3);transition:all .18s}
.mq-react:hover{border-color:var(--border2);color:var(--text2);transform:translateY(-1px)}
.mq-react.on{background:rgba(245,160,48,.12);border-color:rgba(245,160,48,.4);color:var(--amber)}

/* spinner */
.mq-spin{width:34px;height:34px;border-radius:50%;border:2px solid rgba(255,200,80,.14);border-top-color:var(--amber);animation:mq-spin 0.9s linear infinite}
@keyframes mq-spin{to{transform:rotate(360deg)}}

/* utility scroll-hide */
.mq-noscroll{-ms-overflow-style:none;scrollbar-width:none}
.mq-noscroll::-webkit-scrollbar{display:none}

/* ============================================================
   THE ORACLE — conversational assistant (orb + panel)
   ============================================================ */
#oa-orb{position:fixed;right:26px;bottom:26px;z-index:9700;width:62px;height:62px;border-radius:50%;border:none;background:none;cursor:none;padding:0}
#oa-orb .oa-core{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 32% 28%,#FFF4E0 0%,var(--amber) 22%,var(--horizon) 48%,var(--ember) 72%,#6A1E5C 100%);box-shadow:0 10px 36px rgba(245,160,48,.45),0 0 0 1px rgba(255,220,120,.25) inset,0 0 40px rgba(0,212,255,.12);animation:oa-breathe 4.5s ease-in-out infinite}
#oa-orb .oa-ring{position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(255,208,96,.4);animation:oa-ping 3.4s ease-out infinite}
#oa-orb .oa-glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:24px;color:#2A0E12;filter:drop-shadow(0 1px 1px rgba(255,255,255,.35))}
#oa-orb:hover .oa-core{transform:scale(1.07)}
#oa-orb .oa-core{transition:transform .25s}
#oa-orb .oa-orb-badge{position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:50%;background:var(--electric);border:2px solid var(--void);display:none}
@keyframes oa-breathe{0%,100%{box-shadow:0 10px 36px rgba(245,160,48,.4),0 0 40px rgba(0,212,255,.1)}50%{box-shadow:0 14px 50px rgba(245,160,48,.6),0 0 64px rgba(0,212,255,.22)}}
@keyframes oa-ping{0%{transform:scale(1);opacity:.6}80%,100%{transform:scale(1.5);opacity:0}}

#oa-panel{position:fixed;right:26px;bottom:26px;z-index:9701;width:392px;height:min(620px,82vh);background:linear-gradient(165deg,rgba(16,9,40,.97),rgba(22,9,46,.97));backdrop-filter:blur(26px);border:1px solid rgba(255,200,80,.16);border-radius:24px;box-shadow:0 50px 120px rgba(0,0,0,.72),0 0 70px rgba(245,160,48,.06);display:none;flex-direction:column;overflow:hidden;transform-origin:bottom right}
#oa-panel.show{display:flex;animation:oa-in .28s cubic-bezier(.2,.8,.3,1)}
@keyframes oa-in{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
.oa-head{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.oa-head .oa-mini{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 32% 28%,#FFF4E0,var(--amber) 30%,var(--horizon) 60%,#6A1E5C);flex-shrink:0;box-shadow:0 0 16px rgba(245,160,48,.4)}
.oa-h-tt{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--cream);line-height:1}
.oa-h-sub{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--electric);margin-top:3px;display:flex;align-items:center;gap:6px}
.oa-h-sub::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--green)}
.oa-x{margin-left:auto;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text2);font-size:14px;display:flex;align-items:center;justify-content:center}
.oa-x:hover{background:rgba(255,200,80,.12);color:var(--cream)}
.oa-log{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:16px}
.oa-log::-webkit-scrollbar{width:7px}.oa-log::-webkit-scrollbar-thumb{background:rgba(255,200,80,.14);border-radius:4px}

.oa-msg{display:flex;gap:10px;align-items:flex-start;max-width:100%}
.oa-msg.user{flex-direction:row-reverse}
.oa-msg .oa-av{width:26px;height:26px;border-radius:50%;flex-shrink:0;background:radial-gradient(circle at 32% 28%,#FFF4E0,var(--amber) 35%,var(--horizon) 65%,#6A1E5C);box-shadow:0 0 12px rgba(245,160,48,.35);margin-top:2px}
.oa-msg.user .oa-av{background:linear-gradient(135deg,var(--burnt),var(--horizon))}
.oa-bubble{font-size:14px;line-height:1.55;color:var(--text);background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:16px;border-top-left-radius:5px;padding:11px 14px;max-width:84%}
.oa-msg.user .oa-bubble{background:linear-gradient(135deg,rgba(155,48,24,.42),rgba(208,84,24,.36));border-color:rgba(245,160,48,.3);border-top-left-radius:16px;border-top-right-radius:5px;color:var(--cream)}
.oa-bubble em{font-style:italic;color:var(--amber)}
.oa-bubble b{color:var(--cream)}
.oa-wide{max-width:100%;width:100%}

.oa-think{display:inline-flex;gap:5px;padding:4px 2px}
.oa-think i{width:7px;height:7px;border-radius:50%;background:var(--horizon);animation:oa-td 1.1s infinite}
.oa-think i:nth-child(2){animation-delay:.18s}.oa-think i:nth-child(3){animation-delay:.36s}
@keyframes oa-td{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

/* result grid of poster cards */
.oa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:11px;margin-top:10px}
.oa-card{position:relative;cursor:none}
.oa-card-poster{width:100%;aspect-ratio:2/3;border-radius:9px;overflow:hidden;background:linear-gradient(145deg,#1A0830,#2C0820);border:1px solid rgba(255,200,80,.1);position:relative;transition:border-color .2s,transform .2s}
.oa-card:hover .oa-card-poster{border-color:rgba(255,200,80,.4);transform:translateY(-3px)}
.oa-card-poster img{width:100%;height:100%;object-fit:cover}
.oa-card-sc{position:absolute;top:5px;right:5px;font-family:var(--mono);font-size:9px;font-weight:700;color:var(--amber);background:rgba(4,2,26,.78);border-radius:5px;padding:2px 5px;backdrop-filter:blur(6px)}
.oa-card-nm{font-family:var(--sans);font-size:10.5px;font-weight:600;color:var(--cream);margin-top:5px;line-height:1.2;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.oa-card-yr{font-family:var(--mono);font-size:9px;color:var(--text3);letter-spacing:.04em;margin-top:1px}
.oa-card-ov{position:absolute;inset:0;border-radius:9px;background:linear-gradient(to top,rgba(4,2,26,.92),rgba(4,2,26,.1) 60%,transparent);opacity:0;transition:opacity .2s;display:flex;flex-direction:column;justify-content:flex-end;gap:5px;padding:8px}
.oa-card:hover .oa-card-ov{opacity:1}
.oa-mini-acts{display:flex;gap:4px;flex-wrap:wrap}
.oa-ma{flex:1;min-width:0;font-size:11px;text-align:center;padding:5px 0;border-radius:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);color:#fff;transition:all .15s}
.oa-ma:hover{background:rgba(245,160,48,.3);border-color:rgba(245,160,48,.5)}
.oa-ma.primary{background:linear-gradient(135deg,var(--ember),var(--horizon));border:none;color:var(--void)}

/* chips */
.oa-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
.oa-chip{font-family:var(--mono);font-size:10px;letter-spacing:.04em;padding:7px 12px;border-radius:999px;border:1px solid var(--border2);color:var(--text2);background:rgba(255,255,255,.03);transition:all .18s;text-align:left}
.oa-chip:hover{border-color:rgba(255,200,80,.4);color:var(--cream);background:rgba(255,200,80,.06)}
.oa-chip.on{background:rgba(255,208,96,.14);border-color:rgba(255,208,96,.45);color:var(--amber)}

/* marathon timeline */
.oa-mara{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.oa-mara-step{display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:13px;padding:9px;position:relative}
.oa-mara-step .oa-mp{width:42px;height:63px;border-radius:7px;overflow:hidden;flex-shrink:0;background:#1A0830;display:flex;align-items:center;justify-content:center;font-size:16px}
.oa-mara-step .oa-mp img{width:100%;height:100%;object-fit:cover}
.oa-mara-info{flex:1;min-width:0}
.oa-mara-stage{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--horizon)}
.oa-mara-nm{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--cream);line-height:1.15;margin-top:1px}
.oa-mara-meta{font-family:var(--mono);font-size:9px;color:var(--text3);margin-top:2px}
.oa-mara-tot{font-family:var(--mono);font-size:10px;color:var(--text2);letter-spacing:.06em;text-align:center;margin-top:2px}
.oa-actions{display:flex;gap:8px;margin-top:11px;flex-wrap:wrap}
.oa-btn{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.06em;padding:10px 16px;border-radius:999px;border:none;transition:all .2s;flex:1;text-align:center}
.oa-btn.fire{background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));color:var(--void)}
.oa-btn.fire:hover{box-shadow:0 8px 24px rgba(245,160,48,.4)}
.oa-btn.ghost{background:rgba(255,255,255,.05);border:1px solid var(--border2);color:var(--text2)}
.oa-btn.ghost:hover{color:var(--cream);border-color:rgba(255,200,80,.4)}

/* six degrees chain */
.oa-chain{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px}
.oa-node{display:flex;flex-direction:column;align-items:center;gap:4px;width:64px}
.oa-node .oa-np{width:54px;height:54px;border-radius:50%;overflow:hidden;background:#1A0830;border:1px solid rgba(255,200,80,.2);display:flex;align-items:center;justify-content:center;font-size:18px}
.oa-node .oa-np.film{width:44px;height:64px;border-radius:7px}
.oa-node .oa-np img{width:100%;height:100%;object-fit:cover}
.oa-node-nm{font-family:var(--mono);font-size:9px;color:var(--text2);text-align:center;line-height:1.15}
.oa-arrow{color:var(--horizon);font-size:13px;flex-shrink:0}

/* compare table */
.oa-vs{margin-top:12px;display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}
.oa-vs-side{text-align:center}
.oa-vs-poster{width:78px;height:117px;border-radius:9px;overflow:hidden;margin:0 auto 8px;background:#1A0830}
.oa-vs-poster img{width:100%;height:100%;object-fit:cover}
.oa-vs-nm{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--cream);line-height:1.15}
.oa-vs-sc{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--amber);margin-top:4px}
.oa-vs-meta{font-family:var(--mono);font-size:9px;color:var(--text3);margin-top:2px}
.oa-vs-mid{font-family:var(--mono);font-size:11px;color:var(--horizon);font-weight:700}

/* provider pills */
.oa-prov{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
.oa-prov-pill{display:flex;align-items:center;gap:7px;padding:6px 11px;border-radius:999px;border:1px solid var(--border2);background:rgba(255,255,255,.03);font-size:12px;color:var(--text)}
.oa-prov-pill img{width:20px;height:20px;border-radius:5px}
.oa-prov-kind{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--text3)}

/* compatibility list */
.oa-match{display:flex;align-items:center;gap:11px;padding:9px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.02);margin-top:8px}
.oa-match-info{flex:1;min-width:0}
.oa-match-nm{font-size:13px;font-weight:600;color:var(--cream)}
.oa-match-sh{font-family:var(--mono);font-size:9px;color:var(--text3);margin-top:2px}
.oa-match-pct{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--amber);flex-shrink:0}
.oa-match-follow{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--horizon);border:1px solid var(--border2);border-radius:999px;padding:6px 12px;flex-shrink:0}
.oa-match-follow:hover{border-color:rgba(255,200,80,.4);color:var(--amber)}

/* input row */
.oa-input{display:flex;align-items:center;gap:9px;padding:13px 16px;border-top:1px solid var(--border);background:rgba(8,4,32,.4)}
.oa-text{flex:1;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:999px;padding:11px 16px;font-family:var(--sans);font-size:13px;color:var(--text);outline:none;transition:border-color .2s}
.oa-text:focus{border-color:var(--border2)}
.oa-text::placeholder{color:var(--text3)}
.oa-mic,.oa-send{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;border:none;transition:all .2s}
.oa-mic{background:rgba(255,255,255,.05);border:1px solid var(--border2);color:var(--text2)}
.oa-mic:hover{color:var(--cream);border-color:rgba(255,200,80,.4)}
.oa-mic.live{background:rgba(232,120,32,.25);border-color:var(--ember);color:var(--amber);animation:oa-breathe 1.2s infinite}
.oa-send{background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));color:var(--void)}
.oa-send:hover{box-shadow:0 8px 22px rgba(245,160,48,.4)}

/* surprise / single hero pick */
.oa-pick{display:flex;gap:14px;margin-top:11px;background:linear-gradient(135deg,rgba(0,212,255,.07),rgba(245,160,48,.05));border:1px solid rgba(0,212,255,.2);border-radius:14px;padding:12px}
.oa-pick-poster{width:84px;height:126px;border-radius:9px;overflow:hidden;flex-shrink:0;background:#1A0830;display:flex;align-items:center;justify-content:center;font-size:22px}
.oa-pick-poster img{width:100%;height:100%;object-fit:cover}
.oa-pick-info{flex:1;min-width:0}
.oa-pick-nm{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--cream);line-height:1.12}
.oa-pick-meta{font-family:var(--mono);font-size:9px;color:var(--text3);margin-top:3px;letter-spacing:.05em}
.oa-pick-ov{font-family:var(--serif);font-size:13px;font-weight:300;color:rgba(255,225,190,.78);line-height:1.45;margin-top:7px}
.oa-pick-why{font-size:12px;color:var(--electric);margin-top:8px;line-height:1.4}

/* person banner — "view full page" for a filmography */
.oa-person{display:flex;align-items:center;gap:12px;margin-top:11px;padding:11px;border-radius:14px;background:linear-gradient(135deg,rgba(245,160,48,.1),rgba(224,128,204,.06));border:1px solid rgba(255,200,80,.2)}
.oa-person-pic{width:50px;height:50px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(145deg,#1A0830,#2C1848);display:flex;align-items:center;justify-content:center;font-size:22px;border:1px solid rgba(255,200,80,.2)}
.oa-person-pic img{width:100%;height:100%;object-fit:cover}
.oa-person-info{flex:1;min-width:0}
.oa-person-nm{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--cream);line-height:1.1}
.oa-person-sub{font-family:var(--mono);font-size:9px;color:var(--text3);margin-top:3px;letter-spacing:.05em}
.oa-person-go{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--void);background:linear-gradient(135deg,var(--ember),var(--horizon));padding:9px 14px;border-radius:999px;text-decoration:none;flex-shrink:0;transition:box-shadow .2s,transform .2s}
.oa-person-go:hover{box-shadow:0 8px 22px rgba(245,160,48,.45);transform:translateY(-1px)}
/* cast strip (main character / lead answer) */
.oa-cast{display:flex;gap:10px;overflow-x:auto;margin-top:11px;padding-bottom:4px;scrollbar-width:none}
.oa-cast::-webkit-scrollbar{display:none}
.oa-castcard{flex:0 0 84px;text-align:center;text-decoration:none;cursor:none;transition:transform .2s}
.oa-castcard:hover{transform:translateY(-3px)}
.oa-castcard img,.oa-castmono{width:84px;height:112px;border-radius:10px;border:1px solid var(--border);display:block;object-fit:cover}
.oa-castmono{background:linear-gradient(145deg,#1A0830,#2C1848);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:30px;color:var(--horizon)}
.oa-castcard.lead img,.oa-castcard.lead .oa-castmono{border-color:rgba(245,160,48,.55);box-shadow:0 0 0 1px rgba(245,160,48,.3)}
.oa-castnm{font-family:var(--sans);font-size:11px;font-weight:600;color:var(--cream);margin-top:7px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.oa-castchar{font-family:var(--mono);font-size:9px;color:var(--text3);margin-top:2px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── LOG / REVIEW MODAL (MQ.openLog) ── */
#mq-log{position:fixed;inset:0;z-index:9800;display:none;align-items:center;justify-content:center;padding:24px}
#mq-log.show{display:flex}
.mqlog-bg{position:absolute;inset:0;background:rgba(3,1,14,.86);backdrop-filter:blur(20px)}
#mq-log.show .mqlog-box{animation:mqlogpop .3s cubic-bezier(.2,.8,.25,1)}
@keyframes mqlogpop{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.mqlog-box{position:relative;z-index:2;width:100%;max-width:660px;display:grid;grid-template-columns:210px 1fr;background:linear-gradient(135deg,#0E0828,#18082C);border:1px solid rgba(255,200,80,.16);border-radius:22px;overflow:hidden;box-shadow:0 48px 120px rgba(0,0,0,.8);max-height:92vh}
.mqlog-poster{position:relative;background:linear-gradient(145deg,#1A0830,#2C0820);display:flex;align-items:center;justify-content:center;font-size:48px;overflow:hidden}
.mqlog-poster img{width:100%;height:100%;object-fit:cover}
.mqlog-poster::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 60%,rgba(14,8,40,.55) 100%)}
.mqlog-body{padding:26px 26px 22px;overflow-y:auto}
.mqlog-close{position:absolute;top:14px;right:14px;z-index:3;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text2);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:none}
.mqlog-close:hover{border-color:var(--ember);color:var(--ember)}
.mqlog-eyebrow{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--horizon);margin-bottom:8px}
.mqlog-title{font-family:var(--serif);font-size:27px;font-weight:700;color:var(--cream);line-height:1.06}
.mqlog-meta{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:.06em;margin-top:6px}
.mqlog-lbl{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3);margin:18px 0 8px}
.mqlog-rate{display:flex;align-items:center;gap:12px}
.mqlog-stars{display:flex;gap:4px}
.mqlog-star{position:relative;width:34px;height:38px;background:none;border:none;padding:0;cursor:none;line-height:38px;font-size:33px}
.mqlog-star:hover{transform:scale(1.05)}
.mqlog-star .base,.mqlog-star .fill{position:absolute;left:0;top:0;height:100%;display:block;pointer-events:none}
.mqlog-star .base{color:rgba(255,255,255,.17)}
.mqlog-star .fill{width:0;overflow:hidden;color:var(--amber);white-space:nowrap;transition:width .08s;filter:drop-shadow(0 0 6px rgba(255,208,96,.4))}
.mqlog-rnum{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--amber)}
.mqlog-ta{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:12px;padding:13px 15px;font-family:var(--serif);font-size:15px;font-weight:300;color:var(--text);line-height:1.6;resize:none;min-height:96px;outline:none;cursor:none;transition:border-color .2s}
.mqlog-ta:focus{border-color:var(--border2)}
.mqlog-toggles{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.mqlog-tog{font-family:var(--mono);font-size:10px;letter-spacing:.05em;padding:9px 15px;border-radius:999px;border:1px solid var(--border2);color:var(--text2);background:rgba(255,255,255,.03);cursor:none;transition:all .18s}
.mqlog-tog:hover{border-color:rgba(255,200,80,.4);color:var(--cream)}
.mqlog-tog.on{background:rgba(255,208,96,.14);border-color:rgba(255,208,96,.5);color:var(--amber)}
.mqlog-date{margin-top:2px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;padding:9px 13px;font-family:var(--mono);font-size:12px;color:var(--text);outline:none;cursor:none;color-scheme:dark}
.mqlog-date:focus{border-color:var(--border2)}
.mqlog-foot{display:flex;gap:10px;margin-top:22px}
.mqlog-save{flex:1;border:none;border-radius:12px;padding:14px;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--void);background:linear-gradient(135deg,var(--burnt),var(--ember),var(--horizon));cursor:none;transition:box-shadow .2s,transform .2s}
.mqlog-save:hover{box-shadow:0 12px 30px rgba(245,160,48,.45);transform:translateY(-1px)}
@media(max-width:560px){
  .mqlog-box{grid-template-columns:1fr;max-height:94vh}
  .mqlog-poster{height:150px}
}
.oa-person.rich{align-items:flex-start}
.oa-person.rich .oa-person-go{margin-top:2px}
.oa-person-sub2{font-family:var(--mono);font-size:9px;color:var(--horizon);margin-top:5px;letter-spacing:.05em;line-height:1.5}
.oa-person-bio{font-family:var(--sans);font-size:11px;line-height:1.55;color:var(--text2);margin-top:7px}
.oa-sub{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--text3);margin:15px 0 1px}

/* ===================== KEYBOARD FOCUS (accessibility) =====================
   Keyboard-only rings via :focus-visible — mouse / touch interaction stays
   ringless so the cinematic feel is untouched, while keyboard users get a clear,
   on-brand amber indicator. The ring is a layered box-shadow (void gap → amber
   ring → soft glow) so it (a) can't be suppressed by the app's many
   `outline:none` inputs and (b) hugs each element's own border-radius. A
   transparent outline keeps Windows High-Contrast working (forced-colors below). */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible,
select:focus-visible, summary:focus-visible, [tabindex]:focus-visible,
[role="button"]:focus-visible, [role="link"]:focus-visible, [role="option"]:focus-visible,
[role="tab"]:focus-visible, [contenteditable]:focus-visible{
  outline:2px solid transparent;
  outline-offset:2px;
  box-shadow:0 0 0 2px var(--void,#04021A), 0 0 0 4px var(--amber,#FFD060), 0 0 18px 2px rgba(255,208,96,.5);
  position:relative;
  z-index:6;
}
/* belt-and-braces: never leave a ring on a mouse / programmatic focus */
:focus:not(:focus-visible){ outline:none; }

/* Card-style tiles often sit inside overflow-clipped scroll rows where an outer
   ring would be cut off — use an INSET amber frame (always fully visible) plus
   the outer glow for when it isn't clipped. */
.card:focus-visible, .oa-card:focus-visible, .mq-tcard:focus-visible, .fav-card:focus-visible,
.pf-row:focus-visible, .pgrid-card:focus-visible, .cw-card:focus-visible, .llist-card:focus-visible,
.tm-item:focus-visible, .diary-entry:focus-visible, .seeall:focus-visible{
  outline:2px solid transparent;
  box-shadow:inset 0 0 0 2px var(--amber,#FFD060), 0 0 0 2px var(--void,#04021A), 0 0 0 4px var(--amber,#FFD060), 0 0 22px 3px rgba(255,208,96,.5);
  border-radius:12px;
}

/* Windows High-Contrast / forced-colors: box-shadows are dropped — fall back to
   a real, system-colored outline. */
@media (forced-colors: active){
  a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible,
  select:focus-visible, [tabindex]:focus-visible, [role="button"]:focus-visible,
  .card:focus-visible, .oa-card:focus-visible, .mq-tcard:focus-visible{
    outline:3px solid Highlight; outline-offset:2px; box-shadow:none;
  }
}

@media(max-width:560px){
  #oa-panel{right:0;left:0;bottom:0;width:100%;height:88vh;border-radius:22px 22px 0 0}
  #oa-orb{right:18px;bottom:18px}
}

/* ===================== CONSENT / PRIVACY (GDPR / CCPA) ===================== */
.mqc-banner{position:fixed;left:0;right:0;bottom:0;z-index:9400;padding:16px;transform:translateY(135%);transition:transform .42s cubic-bezier(.2,.8,.2,1);pointer-events:none}
.mqc-banner.show{transform:translateY(0)}
body.mq-consenting #oa-orb{opacity:0;pointer-events:none;transition:opacity .3s}
.mqc-inner{pointer-events:auto;max-width:1080px;margin:0 auto;background:linear-gradient(150deg,rgba(14,8,40,.97),rgba(24,8,44,.97));border:1px solid var(--border2);border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.65);padding:18px 22px;display:flex;align-items:center;gap:24px;backdrop-filter:blur(20px)}
.mqc-txt{flex:1;min-width:0}
.mqc-h{font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.01em;color:var(--cream);margin-bottom:5px}
.mqc-txt p{font-family:var(--sans);font-size:12.5px;line-height:1.55;color:var(--text2)}
.mqc-txt a{color:var(--amber);border-bottom:1px solid rgba(255,208,96,.35);white-space:nowrap}
.mqc-btns{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.mqc-btn{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:11px 16px;border-radius:999px;border:1px solid var(--border2);background:rgba(255,255,255,.04);color:var(--text);transition:all .2s;white-space:nowrap}
.mqc-btn:hover{border-color:var(--horizon);color:var(--cream)}
.mqc-btn.ghost{background:none;color:var(--text2)}
.mqc-btn.gold{background:linear-gradient(135deg,var(--amber),var(--horizon));border-color:transparent;color:#1a0c04;font-weight:700}
.mqc-btn.gold:hover{filter:brightness(1.07)}
@media(max-width:680px){.mqc-inner{flex-direction:column;align-items:stretch;gap:14px}.mqc-btns{justify-content:stretch}.mqc-btn{flex:1;text-align:center}}

.mqcp-modal{position:fixed;inset:0;z-index:9600;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .3s;pointer-events:none}
.mqcp-modal.show{opacity:1;pointer-events:auto}
.mqcp-bg{position:absolute;inset:0;background:rgba(4,2,16,.74);backdrop-filter:blur(6px)}
.mqcp-box{position:relative;z-index:2;width:100%;max-width:480px;background:linear-gradient(150deg,#0E0828,#18082C);border:1px solid var(--border2);border-radius:20px;box-shadow:0 48px 100px rgba(0,0,0,.8);overflow:hidden;transform:translateY(10px) scale(.98);transition:transform .3s}
.mqcp-modal.show .mqcp-box{transform:none}
.mqcp-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}
.mqcp-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--cream)}
.mqcp-x{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text2);font-size:13px;transition:all .2s}
.mqcp-x:hover{color:var(--cream);border-color:var(--horizon)}
.mqcp-body{padding:6px 20px}
.mqcp-row{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}
.mqcp-row:last-child{border-bottom:none}
.mqcp-row-tx{flex:1}
.mqcp-row-h{font-family:var(--sans);font-weight:600;font-size:13px;color:var(--cream);margin-bottom:5px;display:flex;align-items:center;gap:8px}
.mqcp-always{font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--green);border:1px solid rgba(128,212,160,.3);border-radius:999px;padding:2px 7px}
.mqcp-row-d{font-family:var(--sans);font-size:11.5px;line-height:1.5;color:var(--text2)}
.mqcp-toggle{flex-shrink:0;width:46px;height:26px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--border2);position:relative;transition:background .2s;margin-top:2px}
.mqcp-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--text3);transition:all .22s}
.mqcp-toggle.on{background:linear-gradient(135deg,var(--amber),var(--horizon))}
.mqcp-toggle.on .mqcp-knob{left:22px;background:#1a0c04}
.mqcp-toggle.locked{opacity:.9;background:rgba(128,212,160,.18);cursor:not-allowed}
.mqcp-toggle.locked .mqcp-knob{left:22px;background:var(--green)}
.mqcp-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 20px;border-top:1px solid var(--border)}
.mqcp-link{font-family:var(--sans);font-size:11px;color:var(--text2)}
.mqcp-link:hover{color:var(--amber)}
.mqcp-save{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:11px 20px;border-radius:999px;background:linear-gradient(135deg,var(--amber),var(--horizon));color:#1a0c04;transition:filter .2s}
.mqcp-save:hover{filter:brightness(1.07)}

/* Settings → Privacy & Data tab */
.mqs-priv-note{font-family:var(--sans);font-size:12.5px;line-height:1.6;color:var(--text2);background:rgba(255,200,80,.04);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.mqs-priv-note b{color:var(--cream)}
.mqs-priv-stat{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0}
.mqs-priv-stat span{flex:1;min-width:110px;font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text2);background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:10px;padding:12px 10px;text-align:center}
.mqs-priv-stat b{display:block;font-family:var(--serif);font-size:20px;color:var(--amber);margin-bottom:2px}
.mqs-priv-acts{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.mqs-priv-btn{display:block;width:100%;text-align:left;font-family:var(--sans);font-weight:600;font-size:12.5px;color:var(--text);padding:13px 16px;border-radius:12px;border:1px solid var(--border2);background:rgba(255,255,255,.03);transition:all .2s}
.mqs-priv-btn:hover{border-color:var(--horizon);background:rgba(255,200,80,.06);color:var(--cream)}
.mqs-priv-btn.danger{color:#ff9b8a;border-color:rgba(255,90,60,.25)}
.mqs-priv-btn.danger:hover{border-color:#ff6a48;background:rgba(255,80,50,.08);color:#ffb3a4}
.mqs-priv-hint{font-family:var(--sans);font-size:11px;color:var(--text3);margin-top:12px;line-height:1.5}

/* ============================================================
   TASTE FUSION — blend two friends' DNA into a shared pick
   ============================================================ */
/* ---- in-chat bubble ---- */
.mqf-row{display:flex;justify-content:center;width:100%;margin:12px 0}
.mqf-bubble{width:min(346px,88%);position:relative;overflow:hidden;text-align:center;padding:18px 18px 16px;border-radius:20px;border:1px solid rgba(255,200,80,.22);background:linear-gradient(158deg,rgba(224,128,204,.11),rgba(0,212,255,.06) 52%,rgba(245,160,48,.09));box-shadow:0 18px 50px rgba(0,0,0,.42)}
.mqf-bubble::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 55% at 50% 0%,rgba(245,160,48,.16),transparent 70%)}
.mqf-bubble>*{position:relative}
.mqf-heads{display:flex;align-items:center;justify-content:center;margin-bottom:11px}
.mqf-heads .mq-av{border:2px solid rgba(8,4,32,.92);box-shadow:0 4px 14px rgba(0,0,0,.45)}
.mqf-heads .mq-av:first-of-type{margin-right:-9px}
.mqf-heads .mq-av:last-of-type{margin-left:-9px}
.mqf-glyph{position:relative;z-index:2;font-size:16px;margin:0 -1px;filter:drop-shadow(0 0 9px rgba(245,160,48,.75));animation:mqf-pulse 2s ease-in-out infinite}
@keyframes mqf-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.mqf-b-tt{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--cream);line-height:1.2}
.mqf-b-tt.muted{color:var(--text2)}
.mqf-b-sub{font-family:var(--sans);font-size:12px;color:var(--text2);margin-top:5px;line-height:1.45}
.mqf-b-acts{display:flex;gap:8px;margin-top:14px}
.mqf-b-acts .oa-btn{flex:1;padding:11px 10px;font-size:11px}
.mqf-wait{display:flex;gap:5px;justify-content:center;margin-top:14px}
.mqf-wait i{width:7px;height:7px;border-radius:50%;background:var(--horizon);animation:mqf-bounce 1.2s infinite}
.mqf-wait i:nth-child(2){animation-delay:.18s}.mqf-wait i:nth-child(3){animation-delay:.36s}
@keyframes mqf-bounce{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}
.mqf-bubble.declined{opacity:.72;background:rgba(255,255,255,.02);border-color:var(--border);box-shadow:none}
.mqf-done{display:flex;align-items:center;gap:11px;text-align:left;background:rgba(4,2,26,.42);border:1px solid var(--border);border-radius:13px;padding:9px;margin-top:13px}
.mqf-done-poster{width:46px;height:69px;border-radius:7px;overflow:hidden;flex-shrink:0;background:#1A0830;display:flex;align-items:center;justify-content:center;font-size:18px}
.mqf-done-poster img{width:100%;height:100%;object-fit:cover}
.mqf-done-info{min-width:0}
.mqf-done-nm{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--cream);line-height:1.15}
.mqf-done-meta{font-family:var(--mono);font-size:9px;color:var(--text3);letter-spacing:.05em;margin-top:3px}

/* ---- the Fusion Theater (full-screen cinematic reveal) ---- */
#mqf-theater{position:fixed;inset:0;z-index:9850;display:none;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse 85% 80% at 50% 28%,rgba(30,9,72,.42),rgba(4,2,26,.97));backdrop-filter:blur(26px)}
#mqf-theater.show{display:flex;animation:mqf-fade .4s ease}
@keyframes mqf-fade{from{opacity:0}to{opacity:1}}
.mqf-fx{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.mqf-close{position:absolute;top:22px;right:24px;z-index:5;width:42px;height:42px;border-radius:50%;border:1px solid var(--border2);background:rgba(8,4,32,.6);color:var(--text2);font-size:16px}
.mqf-close:hover{color:var(--cream);border-color:var(--horizon)}
.mqf-stage{position:relative;z-index:2;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;text-align:center;padding:8px 8px 16px}
.mqf-title{font-family:var(--serif);font-size:13px;font-weight:700;letter-spacing:.42em;text-transform:uppercase;color:var(--horizon);text-shadow:0 0 24px rgba(245,160,48,.5)}
.mqf-sub{font-family:var(--mono);font-size:11px;color:var(--text2);letter-spacing:.16em;text-transform:uppercase;margin-top:7px}
.mqf-merge{display:flex;align-items:center;justify-content:center;gap:6px;margin:28px 0 4px}
.mqf-person{display:flex;flex-direction:column;align-items:center;gap:10px;width:100px}
.mqf-person.left{animation:mqf-slideL .8s cubic-bezier(.2,.8,.2,1)}
.mqf-person.right{animation:mqf-slideR .8s cubic-bezier(.2,.8,.2,1)}
@keyframes mqf-slideL{from{opacity:0;transform:translateX(-44px)}to{opacity:1;transform:none}}
@keyframes mqf-slideR{from{opacity:0;transform:translateX(44px)}to{opacity:1;transform:none}}
.mqf-av{position:relative}
.mqf-av::after{content:'';position:absolute;inset:-7px;border-radius:50%;z-index:-1;filter:blur(10px);opacity:.55;background:conic-gradient(from 0deg,var(--horizon),var(--electric),var(--magenta),var(--horizon));animation:mqf-spin 6s linear infinite}
@keyframes mqf-spin{to{transform:rotate(360deg)}}
.mqf-av .mq-av{border:2px solid rgba(255,240,224,.5)}
.mqf-pname{font-family:var(--sans);font-size:13px;font-weight:700;color:var(--cream)}
.mqf-helix{position:relative;width:92px;height:104px;flex-shrink:0;align-self:center}
.mqf-rung{position:absolute;left:50%;top:calc(4px + var(--i) * 5.3px);width:0;height:0}
.mqf-rung i{position:absolute;top:0;left:0;width:8px;height:8px;margin:-4px 0 0 -4px;border-radius:50%;animation:mqf-helix 2.4s linear infinite;animation-delay:calc(var(--i) * -0.13s)}
.mqf-rung i:first-child{background:var(--horizon);box-shadow:0 0 10px var(--horizon)}
.mqf-rung i:last-child{background:var(--electric);box-shadow:0 0 10px var(--electric);animation-delay:calc(var(--i) * -0.13s - 1.2s)}
@keyframes mqf-helix{0%{transform:translateX(-36px) scale(.55);opacity:.35}50%{transform:translateX(36px) scale(1.1);opacity:1}100%{transform:translateX(-36px) scale(.55);opacity:.35}}
.mqf-ringwrap{position:relative;width:132px;height:132px;margin:24px auto 0}
.mqf-ring{width:132px;height:132px;transform:rotate(-90deg)}
.mqf-ring circle{fill:none;stroke-width:8;stroke-linecap:round}
.mqf-ring-bg{stroke:rgba(255,255,255,.08)}
.mqf-ring-fg{stroke:var(--amber);stroke-dasharray:327;stroke-dashoffset:327;filter:drop-shadow(0 0 6px rgba(255,208,96,.7))}
.mqf-ring.go .mqf-ring-fg{transition:stroke-dashoffset 1.6s cubic-bezier(.2,.8,.2,1);stroke-dashoffset:calc(327 - 327 * (var(--p,0) / 100))}
.mqf-ringtxt{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:42px;font-weight:700;color:var(--cream)}
.mqf-ringtxt i{font-size:18px;font-style:normal;color:var(--horizon);margin-top:9px}
.mqf-ringlbl{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--text2);margin-top:9px}
.mqf-bars{max-width:300px;margin:22px auto 0;display:flex;flex-direction:column;gap:9px}
.mqf-bar{display:flex;align-items:center;gap:11px}
.mqf-bar-l{flex:0 0 80px;text-align:right;font-family:var(--mono);font-size:9.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mqf-bar-t{flex:1;height:7px;border-radius:5px;background:rgba(255,255,255,.06);overflow:hidden}
.mqf-bar-t i{display:block;height:100%;width:0;border-radius:5px;background:linear-gradient(90deg,var(--ember),var(--horizon),var(--amber))}
.mqf-bar-t i.go{width:var(--w);transition:width 1.1s cubic-bezier(.2,.8,.2,1)}
.mqf-status{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--horizon);margin-top:22px;animation:mqf-flick 1.6s ease-in-out infinite}
@keyframes mqf-flick{0%,100%{opacity:.5}50%{opacity:1}}
#mqf-theater.revealed .mqf-merge,#mqf-theater.revealed .mqf-ringwrap,#mqf-theater.revealed .mqf-ringlbl,#mqf-theater.revealed .mqf-bars,#mqf-theater.revealed .mqf-status,#mqf-theater.revealed .mqf-sub{display:none}
.mqf-reveal{margin-top:10px;animation:mqf-rise .7s cubic-bezier(.2,.8,.2,1)}
@keyframes mqf-rise{from{opacity:0;transform:translateY(26px) scale(.96)}to{opacity:1;transform:none}}
.mqf-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:14px}
.mqf-hero{display:flex;gap:18px;text-align:left;background:linear-gradient(150deg,rgba(245,160,48,.1),rgba(224,128,204,.06));border:1px solid rgba(255,200,80,.22);border-radius:18px;padding:16px}
.mqf-hero-poster{width:122px;flex-shrink:0;aspect-ratio:2/3;border-radius:11px;overflow:hidden;background:#1A0830;display:flex;align-items:center;justify-content:center;font-size:30px;box-shadow:0 16px 40px rgba(0,0,0,.5);animation:mqf-pop .8s .15s backwards cubic-bezier(.2,.9,.2,1)}
@keyframes mqf-pop{from{opacity:0;transform:scale(.8) rotate(-3deg)}to{opacity:1;transform:none}}
.mqf-hero-poster img{width:100%;height:100%;object-fit:cover}
.mqf-hero-info{flex:1;min-width:0}
.mqf-hero-nm{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--cream);line-height:1.08}
.mqf-hero-meta{font-family:var(--mono);font-size:10px;color:var(--text2);letter-spacing:.06em;margin-top:6px}
.mqf-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
.mqf-tag{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--horizon);border:1px solid rgba(255,200,80,.28);border-radius:999px;padding:4px 10px}
.mqf-why{font-family:var(--serif);font-size:15px;font-style:italic;font-weight:300;line-height:1.5;color:rgba(255,225,190,.9);margin-top:13px}
.mqf-acts{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px}
.mqf-acts .oa-btn{flex:1;min-width:84px}
.mqf-alts-h{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text2);margin:24px 0 0;text-align:left}
.mqf-alts{margin-top:11px}
@media(max-width:520px){
  .mqf-hero{flex-direction:column;align-items:center;text-align:center}
  .mqf-hero-poster{width:142px}
  .mqf-tags{justify-content:center}
}
