*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#000;--bg2:#121212;--bg3:#1a1a1a;--bg4:#262626;--bg5:#363636;
  --border:#262626;--border2:#363636;
  --text:#f5f5f5;--text2:#a8a8a8;--text3:#737373;
  --blue:#0095f6;--red:#ed4956;--green:#3dd68c;
  --sg:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;overflow-x:hidden}
button{cursor:pointer;border:none;background:none;color:inherit;font-family:inherit;font-size:inherit}
a{color:inherit;text-decoration:none}
input{font-family:inherit;font-size:inherit}
::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}

/* ── LAYOUT ── */
.app-wrap{display:flex;max-width:1300px;margin:0 auto;padding:0 20px}
@media(max-width:900px){
  .app-wrap{display:none}
  #mob-topbar,#mob-feed,#mob-nav{display:flex!important}
  #mob-toggle{display:none!important}
  /* CTA banner always visible at bottom on touch (no hover) */
  #mob-feed .pcta{opacity:1;pointer-events:auto}
}
@media(min-width:901px){
  #mob-topbar,#mob-feed,#mob-nav,#mob-reels-section,#mob-profile-section{display:none!important}
}

/* ── LEFT NAV ── */
#left-nav{width:245px;flex-shrink:0;position:sticky;top:0;height:100vh;padding:20px 12px;display:flex;flex-direction:column;border-right:1px solid var(--border)}
.nav-logo{padding:12px 12px 24px;font-size:22px;font-style:italic;font-weight:700}
.brand-logo{display:block;height:60px;width:auto}
.mob-brand-logo{display:block;height:38px;width:auto}
.ph-brand-logo{display:block;height:34px;width:auto}
.nav-item{display:flex;align-items:center;gap:16px;padding:12px;border-radius:8px;font-size:15px;cursor:pointer;transition:background .15s;white-space:nowrap}
.nav-item:hover{background:var(--bg3)}
.nav-item.active{font-weight:600}
.nav-div{height:1px;background:var(--border);margin:16px 0}
.nav-metrics{padding:4px 12px;display:flex;flex-direction:column;gap:8px}
.mrow{display:flex;justify-content:space-between;align-items:center;color:var(--text2);font-size:13px}
.mval{color:var(--text);font-weight:600}
.exp-plus{font-size:.62em;vertical-align:super;line-height:0;margin-left:1px}
.nav-cv{display:flex;align-items:center;justify-content:center;gap:8px;margin:14px 0 0;padding:11px 14px;border-radius:10px;background:var(--blue);color:#fff;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .15s}
.nav-cv:hover{opacity:.88}
.nav-cv svg{flex:0 0 auto}
.nav-bot{margin-top:auto}

/* ── MAIN FEED ── */
#main-feed{flex:1;max-width:630px;margin:0 auto;padding:0 24px;min-width:0}

/* ── RIGHT PANEL ── */
#right-panel{width:320px;flex-shrink:0;padding:28px 32px;position:sticky;top:0;height:100vh;overflow-y:auto}
.prow{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.pavsm{width:56px;height:56px;border-radius:50%;background:var(--bg3);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px}
.pinfo{flex:1;min-width:0}
.puname{font-size:14px;font-weight:600;margin-bottom:2px}
.pname2{font-size:13px;color:var(--text2)}
.vpbtn{font-size:13px;color:var(--blue);font-weight:600;white-space:nowrap}
.vpbtn:hover{color:#fff}
.rstitle{font-size:14px;font-weight:600;color:var(--text2);margin-bottom:16px}
.trow{display:flex;align-items:center;gap:12px;padding:8px 0}
.tico{width:32px;height:32px;border-radius:8px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;overflow:hidden}
.tico img{width:100%;height:100%;object-fit:cover;display:block}
.tico img[alt="Figma"]{transform:scale(.8)}
.tico:has(img[alt="Figma"]){background:#000}
.tn{font-size:14px;font-weight:600;display:block}
.tc{font-size:12px;color:var(--text3);display:block}
.tlnk{font-size:12px;color:var(--blue);font-weight:600;margin-left:auto}
.rfoot{margin-top:24px;font-size:11px;color:var(--text3);line-height:1.9}

/* ── STORIES ── */
.stories-row{display:flex;gap:4px;padding:16px 0;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border);margin-bottom:8px}
.stories-row::-webkit-scrollbar{display:none}
.si{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;flex-shrink:0;padding:4px 6px;width:72px}
.sr{width:62px;height:62px;border-radius:50%;padding:2px;background:var(--sg);position:relative}
.sr.own{background:transparent;padding:0}
.sr.seen,.psr.seen{background:#8e8e8e}
.sav{width:100%;height:100%;border-radius:50%;background:var(--bg3);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden}
.own-plus{position:absolute;bottom:0;right:0;width:20px;height:20px;box-sizing:border-box;border-radius:50%;background:var(--blue);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:15px;line-height:1;font-weight:400;color:#fff}
.own-plus::before{content:'+';display:block;margin-top:-1px}
.sname{font-size:12px;color:var(--text);text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── POST ── */
.post{border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:4px}
.phdr{display:flex;align-items:center;gap:10px;padding:12px 0}
.pav{width:32px;height:32px;border-radius:50%;background:var(--bg3);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px}
.phdr-info{flex:1}
.puname2{font-size:14px;font-weight:600}
.psub{font-size:12px;color:var(--text3)}
.pmoreBtn{color:var(--text);padding:4px 8px;border-radius:4px;font-size:18px;font-weight:700}
.pmoreBtn:hover{background:var(--bg3)}
.pmedia{position:relative;background:var(--bg3);aspect-ratio:4/5;overflow:hidden;cursor:pointer;user-select:none}
.pph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text3)}
.pph-ico{font-size:40px;opacity:.3}
.pph-txt{font-size:13px;opacity:.5}
.pph-sub{font-size:11px;opacity:.3}
.pcta{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.72);backdrop-filter:blur(2px);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;opacity:0;transition:opacity .2s;pointer-events:none}
.pmedia:hover .pcta{opacity:1;pointer-events:all}
.pcta span{font-size:14px;font-weight:600;color:#fff}
.ctabtn{background:var(--blue);color:#fff;padding:6px 14px;border-radius:4px;font-size:13px;font-weight:600}
.heart-pop{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:80px;pointer-events:none;opacity:0}
@keyframes heartBurst{0%{transform:translate(-50%,-50%) scale(0);opacity:1}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}100%{transform:translate(-50%,-50%) scale(1);opacity:0}}
@keyframes likeAnim{0%{transform:scale(1)}25%{transform:scale(1.4)}50%{transform:scale(.85)}75%{transform:scale(1.2)}100%{transform:scale(1)}}
.pacts{display:flex;align-items:center;gap:4px;padding:8px 0 4px}
.abtn{padding:8px;border-radius:50%;transition:all .1s;color:var(--text);display:flex;align-items:center;justify-content:center}
.abtn:hover{color:var(--text2)}
.abtn.liked svg path{fill:var(--red);stroke:var(--red)}
.abtn.liked{color:var(--red)}
.abtn.saved svg path{fill:var(--text);stroke:var(--text)}
.savebtn{margin-left:auto}
.lcnt{padding:0 4px 4px;font-size:14px;font-weight:600}
.pcap{padding:0 4px;line-height:1.5;margin-bottom:6px}
.pcap .un{font-weight:600;margin-right:6px}
.cap-body.cap-clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cap-toggle{display:inline-block;margin-top:2px;color:var(--text3);font-weight:600;cursor:pointer}
.cap-toggle:hover{color:var(--text2)}
.ptags{color:var(--blue)}
.vcs{padding:2px 4px 4px;font-size:14px;color:var(--text3);cursor:pointer}
.vcs:hover{color:var(--text)}
.ptime{padding:2px 4px 12px;font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.acmt{display:flex;align-items:center;gap:8px;padding:8px 4px;border-top:1px solid var(--border)}
.cav{width:24px;height:24px;border-radius:50%;background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px}
.cinp{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14px;caret-color:var(--text)}
.cinp::placeholder{color:var(--text3)}
.cpost{color:var(--blue);font-weight:600;font-size:14px;opacity:0;transition:opacity .2s}
.cpost.show{opacity:1}

/* ── STORY VIEWER ── */
#sv{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
#sv.open{opacity:1;pointer-events:all}
.svwrap{position:relative;width:min(400px,100vw);height:min(710px,100vh)}
#sv.sv-d .svwrap{width:min(1080px,94vw);height:min(620px,88vh)}
/* Desktop image stories: the viewer hugs the screenshot so it always fills the frame (no letterbox strips) */
#sv.sv-d.sv-img .svwrap{width:auto;height:auto;max-width:min(1100px,94vw);max-height:88vh}
#sv.sv-d.sv-img .svbg,#sv.sv-d.sv-img .svph{width:auto;height:auto}
.svbg{width:100%;height:100%;border-radius:12px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
/* Top scrim so progress bar, name and X stay visible over light/white slides */
.svbg::before{content:'';position:absolute;top:0;left:0;right:0;height:96px;background:linear-gradient(to bottom,rgba(0,0,0,.55),rgba(0,0,0,0));z-index:5;pointer-events:none}
.svph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:rgba(255,255,255,.5);font-size:14px}
.svprogs{position:absolute;top:12px;left:12px;right:12px;display:flex;gap:4px;z-index:10}
.svseg{flex:1;height:2px;background:rgba(255,255,255,.35);border-radius:1px;overflow:hidden}
.svfill{height:100%;background:#fff;width:0%;transition:width .05s linear}
.svfill.done{width:100%}
.svhdr{position:absolute;top:20px;left:12px;right:12px;display:flex;align-items:center;gap:10px;z-index:20}
.svav{width:32px;height:32px;border-radius:50%;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:14px}
.svan{font-weight:600;font-size:14px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.55)}
.svtime{font-size:12px;color:rgba(255,255,255,.7);margin-left:4px;text-shadow:0 1px 3px rgba(0,0,0,.55)}
.svx{margin-left:auto;font-size:24px;color:#fff;opacity:.95;cursor:pointer;line-height:1;padding:8px;position:relative;z-index:25;text-shadow:0 1px 4px rgba(0,0,0,.7)}
.svnl,.svnr{position:absolute;top:0;bottom:0;width:40%;cursor:pointer;z-index:10}
.svnl{left:0}.svnr{right:0}

/* ── CHAT (external) ── */
#chat-panel{position:fixed;bottom:0;right:0;width:min(400px,100vw);height:min(580px,80vh);background:var(--bg2);border:1px solid var(--border);border-radius:16px 16px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.34,1.56,.64,1);z-index:800}
#chat-panel.open{transform:translateY(0)}
/* On phones the chat is a full-screen sheet so the background feed doesn't show behind it */
@media(max-width:600px){
  #chat-panel{width:100vw;height:100vh;height:100dvh;max-height:none;border-radius:0;border:none}
}
.chdr{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.cav2{width:40px;height:40px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:18px}
.cinfo{flex:1}
.cname{font-weight:600;font-size:14px}
.cstatus{font-size:12px;color:var(--text3)}
.cx{font-size:20px;color:var(--text2);cursor:pointer;padding:4px}
.cmsgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.msg{max-width:72%;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.5;word-wrap:break-word}
.msg.me{background:var(--blue);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.msg.them{background:var(--bg4);align-self:flex-start;border-bottom-left-radius:4px}
/* Chat contact CTA buttons */
.cctas{display:flex;flex-direction:column;gap:10px;padding:12px 16px 16px;flex-shrink:0}
.cta-link{display:flex;align-items:center;gap:14px;padding:13px 16px;border-radius:14px;background:var(--bg3);border:1px solid var(--border2);text-decoration:none;color:var(--text);opacity:0;transform:translateY(8px);animation:ctaIn .4s ease forwards;transition:background .2s,border-color .2s,transform .15s}
.cta-link:hover{background:var(--bg4);transform:translateY(-1px)}
.cta-link:active{transform:translateY(0)}
.cta-ico{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:10px}
.cta-ico svg{width:24px;height:24px;display:block}
.cta-txt{display:flex;flex-direction:column;gap:2px;text-align:left;min-width:0}
.cta-title{font-size:14px;font-weight:600;color:var(--text)}
.cta-sub{font-size:12px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cta-link.cta-wa{border-color:rgba(37,211,102,.35)}
.cta-link.cta-wa:hover{border-color:rgba(37,211,102,.6)}
.cta-link.cta-wa .cta-ico{background:#fff}
@keyframes ctaIn{to{opacity:1;transform:translateY(0)}}

/* ── PROFILE MODAL ── */
#pm{position:fixed;inset:0;z-index:850;background:var(--bg);overflow-y:auto;transform:translateX(100%);transition:transform .3s ease}
#pm.open{transform:translateX(0)}
.pmtop{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:10}
.pmback{font-size:20px;cursor:pointer;padding:4px 8px}
.pmun{font-weight:600;font-size:16px}
.pm-main{max-width:800px;margin:0 auto;padding:24px 20px}
.pm-hdr-sec{display:flex;align-items:flex-start;gap:32px;margin-bottom:28px}
.pm-bigav{width:100px;height:100px;border-radius:50%;flex-shrink:0;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:40px;overflow:hidden}
.pm-bigav img{width:100%;height:100%;object-fit:cover}
.pm-info2{flex:1}
.pm-un2{font-size:20px;font-weight:300;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.pm-fn{font-weight:600;font-size:15px;margin-bottom:4px}
.pm-hl{font-size:14px;color:var(--text2);margin-bottom:20px}
.pm-ctabtn{background:var(--blue);color:#fff;border:none;padding:9px 22px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
.pm-ctabtn:hover{background:#1877f2}
.pm-divider{height:1px;background:var(--border);margin-bottom:0}
/* Profile tabs */
.pm-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:0}
.pm-tab{flex:1;padding:14px;text-align:center;font-size:13px;font-weight:500;color:var(--text3);letter-spacing:1px;text-transform:uppercase;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.pm-tab.active{color:var(--text);border-bottom-color:var(--text)}
.pm-tab svg{opacity:.7}
/* Profile grids */
.pm-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:3px}
.pm-gi{background:var(--bg3);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;position:relative}
.pm-gi.vid{background:linear-gradient(135deg,#1a1a2e,#0f3460)}
.pm-gi.txt{padding:20px}
.vid-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:rgba(255,255,255,.4);height:100%;width:100%}
.txt-card{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;padding:24px}
.txt-card p{font-size:15px;line-height:1.65;color:var(--text);font-style:italic}
.txt-author{margin-top:12px;font-size:12px;color:var(--text3)}
.saved-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:3px}
.saved-item{aspect-ratio:1;background:var(--bg3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;overflow:hidden;position:relative}
.saved-item:hover::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.4)}
.saved-ico{font-size:32px;opacity:.6}
.saved-name{font-size:11px;color:var(--text2);font-weight:500}
.saved-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.saved-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;margin:0;padding:14px 10px 8px;text-align:left;color:#fff;font-weight:600;background:linear-gradient(transparent,rgba(0,0,0,.78))}
.saved-empty{grid-column:1/-1;text-align:center;padding:48px 20px;color:var(--text3);font-size:14px}
.saved-empty svg{opacity:.3;margin:0 auto 12px;display:block}

/* ── COMMENT DRAWER ── */
#cdrawer{position:fixed;bottom:0;left:50%;transform:translate(-50%,100%);width:min(630px,100vw);background:var(--bg2);border-radius:16px 16px 0 0;border:1px solid var(--border);max-height:70vh;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.34,1.56,.64,1);z-index:800}
#cdrawer.open{transform:translate(-50%,0)}
.cdhdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.cdtitle{font-size:15px;font-weight:600}
.cdx{font-size:20px;color:var(--text2);cursor:pointer}
.cdlist{flex:1;overflow-y:auto;padding:16px}
.citem{display:flex;gap:10px;margin-bottom:16px}
.ciav{width:32px;height:32px;border-radius:50%;background:var(--bg4);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px}
.ciun{font-weight:600;font-size:13px;margin-right:6px}
.citxt{font-size:14px;line-height:1.4}
.citime{font-size:11px;color:var(--text3);margin-top:4px}
.nocmts{text-align:center;padding:32px;color:var(--text3);font-size:14px}
.comments-loading{text-align:center;padding:24px;color:var(--text3);font-size:13px}
.cdinprow{display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}
.cdav{width:32px;height:32px;border-radius:50%;background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px}
.cdinp{flex:1;background:var(--bg3);border:1px solid var(--border2);border-radius:22px;padding:9px 16px;color:var(--text);outline:none;font-size:14px}
.cdinp::placeholder{color:var(--text3)}
.cdpost{color:var(--blue);font-weight:600;font-size:14px;opacity:.5;transition:opacity .2s;padding:4px 8px}
.cdpost.on{opacity:1}

/* ── POST OPTIONS ── */
#popts{position:fixed;bottom:0;left:50%;transform:translate(-50%,100%);width:min(630px,100vw);background:var(--bg3);border-radius:16px 16px 0 0;border:1px solid var(--border);display:flex;flex-direction:column;transition:transform .3s ease;z-index:810}
#popts.open{transform:translate(-50%,0)}
.optsbar{width:32px;height:3px;background:var(--bg5);border-radius:2px;margin:12px auto 8px}
.optsitem{display:flex;align-items:center;gap:14px;padding:16px 24px;cursor:pointer;border-bottom:1px solid var(--border);font-size:15px;transition:background .15s}
.optsitem:hover{background:var(--bg4)}
.optsitem:last-child{border-bottom:none}
.optsitem.danger{color:var(--red)}

/* ── MORE MODAL ── */
#moremodal{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
#moremodal.open{opacity:1;pointer-events:all}
.morebox{background:var(--bg2);border-radius:20px 20px 0 0;width:min(600px,100vw);padding:24px;border:1px solid var(--border);border-bottom:none;max-height:90vh;overflow-y:auto}
.morebox h3{font-size:18px;font-weight:600;margin-bottom:6px;text-align:center}
.morebox>p{font-size:13px;color:var(--text3);text-align:center;margin-bottom:24px}
.gcards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.gcard{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:24px 16px;cursor:pointer;text-align:center;transition:all .2s}
.gcard:hover{border-color:var(--blue);background:rgba(0,149,246,.08)}
.gcard-ico{font-size:40px;margin-bottom:10px}
.gcard h4{font-size:15px;font-weight:600;margin-bottom:4px}
.gcard p{font-size:12px;color:var(--text3)}
.more-closebtn{width:100%;padding:14px;border-radius:10px;background:var(--bg4);color:var(--text2);font-size:15px;font-weight:500;cursor:pointer;transition:background .2s}
.more-closebtn:hover{background:var(--bg5)}
/* Memory */
#gmem{display:none;padding:8px 0}
.memboard{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:360px;margin:0 auto 20px}
.mcard{aspect-ratio:1;background:var(--bg4);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:28px;transition:all .3s;border:2px solid transparent;user-select:none}
.mcard.fl{background:var(--bg3);border-color:var(--blue)}
.mcard.mt{background:rgba(61,214,140,.1);border-color:var(--green);cursor:default}
.mcard .mfront{display:none}.mcard .mback{display:block;font-size:22px;opacity:.4}
.mcard.fl .mfront,.mcard.mt .mfront{display:block}
.mcard.fl .mback,.mcard.mt .mback{display:none}
.ginfo{text-align:center;color:var(--text2);font-size:14px;margin-bottom:16px}
.gwin{text-align:center;padding:16px;font-size:16px;color:var(--green);font-weight:600;display:none}
.gbkbtn{width:100%;padding:12px;border-radius:10px;background:var(--bg4);color:var(--text2);font-size:14px;cursor:pointer;margin-top:8px}
/* Quiz */
#gquiz{display:none;padding:8px 0}
.qq{font-size:16px;font-weight:600;margin-bottom:20px;text-align:center;line-height:1.5}
.qopts{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.qopt{padding:14px 18px;border-radius:10px;background:var(--bg4);border:2px solid transparent;cursor:pointer;font-size:14px;text-align:left;transition:all .2s}
.qopt:hover:not(.dis){background:var(--bg5)}
.qopt.correct{border-color:var(--green);background:rgba(61,214,140,.1);color:var(--green)}
.qopt.wrong{border-color:var(--red);background:rgba(237,73,86,.1);color:var(--red)}
.qopt.dis{cursor:default}
.qprog{font-size:13px;color:var(--text3);text-align:center;margin-bottom:16px}
.qscore{text-align:center;padding:20px;font-size:16px;display:none}

/* ── NOTIFICATIONS (external/desktop) ── */
#notifpanel{position:fixed;top:0;right:0;width:min(380px,100vw);height:100vh;background:var(--bg);border-left:1px solid var(--border);transform:translateX(100%);transition:transform .3s ease;z-index:880;display:flex;flex-direction:column}
#notifpanel.open{transform:translateX(0)}
.nhdr{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border);flex-shrink:0}
.nhdr h2{font-size:16px;font-weight:600}
.nx{font-size:24px;color:var(--text2);cursor:pointer;line-height:1}
.nlist{flex:1;overflow-y:auto;padding:8px 0}
.nsec{padding:4px 20px 8px;font-size:13px;font-weight:600;color:var(--text2)}
.nitem{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background .15s}
.nitem:hover{background:var(--bg3)}
.nitem.unread{background:rgba(0,149,246,.04)}
.nav2{width:44px;height:44px;border-radius:50%;background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden}
.nav2.ring{background:var(--sg);padding:2px}
.nav2-in{width:100%;height:100%;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:18px;border:2px solid var(--bg)}
.ntxt{flex:1;font-size:14px;line-height:1.4}
.ntime{font-size:12px;color:var(--text3);flex-shrink:0}
.ndot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0}

/* ── PHONE FRAME ── */
#phone-overlay{position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.8);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
#phone-overlay.open{opacity:1;pointer-events:all}
#pframe{width:393px;height:852px;background:#0a0a0a;border-radius:38px;border:8px solid #2a2a2a;box-shadow:0 0 0 1px #1a1a1a,0 40px 100px rgba(0,0,0,.9);overflow:hidden;position:relative;transform:scale(.85);display:flex;flex-direction:column}
.pnotch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:126px;height:34px;background:#0a0a0a;border-radius:0 0 20px 20px;z-index:10}
.pstatus{display:flex;justify-content:space-between;align-items:center;padding:14px 28px 0;font-size:12px;font-weight:600;position:relative;z-index:5}
.pstatus-icons{display:flex;align-items:center;gap:5px}
.pbody{flex:1;min-height:0;overflow:hidden;position:relative}
/* Phone sections */
.psec{position:absolute;inset:0;overflow-y:auto;scrollbar-width:none;transform:translateX(100%);transition:transform .3s ease}
.psec::-webkit-scrollbar{display:none}
.psec.active{transform:translateX(0)}
.psec.prev{transform:translateX(-100%)}
/* Phone internal overlays (stay inside phone) */
.ph-int{position:absolute;inset:0;background:var(--bg);z-index:20;transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;overflow:hidden}
.ph-int.open{transform:translateX(0)}
.ph-int-back{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0;font-weight:600;font-size:15px;cursor:pointer}
.ph-int-back svg{opacity:.7}
/* Phone top bar */
.ptopbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:5}
.plogo{font-size:20px;font-style:italic;font-weight:700}
.ptopicons{display:flex;gap:16px;align-items:center}
.ptopicons svg{cursor:pointer}
/* Phone stories */
.pstories{display:flex;gap:2px;padding:12px 0 12px 16px;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border)}
.pstories::-webkit-scrollbar{display:none}
.ps{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0;width:68px}
.psr{width:58px;height:58px;border-radius:50%;padding:2px;background:var(--sg)}
.psr.own{background:transparent;padding:0;position:relative}
.psav{width:100%;height:100%;border-radius:50%;background:var(--bg3);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:18px}
.psn{font-size:11px;text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Phone mini post */
.ppost{border-bottom:1px solid var(--border)}
.pphdr{display:flex;align-items:center;gap:8px;padding:10px 12px}
.ppav{width:30px;height:30px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:12px}
.ppun{font-size:13px;font-weight:600}
.ppmr{margin-left:auto;font-size:18px;color:var(--text2)}
.ppmedia{background:var(--bg3);aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative}
.ppcta{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.7);padding:8px 12px;display:flex;justify-content:space-between;align-items:center}
.ppacts{display:flex;gap:2px;padding:8px 10px 4px}
.ppact{padding:6px;color:var(--text)}
.ppact.liked svg path{fill:var(--red);stroke:var(--red)}
.ppact.liked{color:var(--red)}
.ppsave{margin-left:auto}
.pplikes{padding:0 12px 4px;font-size:13px;font-weight:600}
.ppcap{padding:0 12px 8px;font-size:13px;line-height:1.5}
.ppcap b{font-weight:600;margin-right:4px}
.pptime{padding:0 12px 10px;font-size:11px;color:var(--text3);text-transform:uppercase}
/* Reels */
.preelvid{background:linear-gradient(135deg,#0a0a1e,#0f3460);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:rgba(255,255,255,.5);padding:60px 20px;text-align:center;min-height:500px}
.preelplay{font-size:64px;opacity:.3}
.preellbl{font-size:16px;font-weight:600;color:rgba(255,255,255,.7)}
.preelsub{font-size:13px;color:rgba(255,255,255,.35)}
.pnomore{text-align:center;padding:40px 24px}
.pnomore .nico{font-size:40px;opacity:.4;margin-bottom:12px}
.pnomore h4{font-size:15px;font-weight:600;color:var(--text2);margin-bottom:6px}
.pnomore p{font-size:13px;color:var(--text3);line-height:1.6}
/* Profile inside phone */
.pprofile{padding:20px}
.pprofhdr{display:flex;align-items:flex-start;gap:20px;margin-bottom:20px}
.pprofav{width:80px;height:80px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0;overflow:hidden}
.pprofav img{width:100%;height:100%;object-fit:cover;display:block}
.pprofinfo{flex:1}
.pprofun{font-size:16px;font-weight:600;margin-bottom:3px}
.pprofname{font-size:14px;font-weight:600;margin-bottom:2px}
.pproftitle{font-size:13px;color:var(--text2);margin-bottom:12px}
.pprofcta-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.pprofcta{flex:1 1 120px;display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;border:none;cursor:pointer;text-decoration:none;white-space:nowrap;transition:filter .15s,background .15s}
.pprofcta:hover{filter:brightness(1.1)}
.pprofcta-sec{background:transparent;color:var(--text);border:1px solid var(--bg4)}
.pprofcta-sec:hover{filter:none;background:var(--bg3)}
.pprofdiv{height:1px;background:var(--border);margin-bottom:0}
/* Tools-I-use highlights (profile / about page) */
.tools-hl{margin:18px 0 4px}
.tools-hl-title{font-size:13px;font-weight:600;color:var(--text2);margin-bottom:12px}
.tools-hl-row{display:flex;flex-wrap:nowrap;gap:14px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;-webkit-overflow-scrolling:touch;cursor:grab}
.tools-hl-row::-webkit-scrollbar{display:none}
.tools-hl-row.dragging{cursor:grabbing;user-select:none}
.tools-hl-row.dragging a{pointer-events:none}
.thl{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:7px;text-decoration:none;width:64px}
.thl-ring{width:60px;height:60px;border-radius:50%;padding:2px;background:var(--sg);transition:transform .15s}
.thl:active .thl-ring{transform:scale(.94)}
.thl-ic{width:100%;height:100%;border-radius:50%;background:var(--bg2);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:23px;overflow:hidden}
.thl-ic img{width:100%;height:100%;object-fit:cover;display:block}
.thl-ic img[alt="Figma"]{transform:scale(.8)}
.thl-ic:has(img[alt="Figma"]){background:#000}
.thl-txt{display:flex;flex-direction:column;align-items:center;line-height:1.25}
.thl-name{font-size:11px;font-weight:500;color:var(--text);max-width:64px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.thl-role{font-size:9.5px;color:var(--text3)}
/* Profile tabs inside phone */
.ptabs{display:flex;border-bottom:1px solid var(--border)}
.ptab{flex:1;padding:12px;text-align:center;font-size:11px;font-weight:500;color:var(--text3);letter-spacing:1px;text-transform:uppercase;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.ptab.active{color:var(--text);border-bottom-color:var(--text)}
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:2px}
.pgi{background:var(--bg3);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.pgvid{background:linear-gradient(135deg,#1a1a2e,#0f3460)}
.pgsaved{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:2px}
.pgsitem{aspect-ratio:1;background:var(--bg3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;overflow:hidden;position:relative}
.pgsitem-ico{font-size:24px;opacity:.5}
.pgsitem-nm{font-size:10px;color:var(--text2)}
/* Phone internal notifications */
.ph-notif-list{flex:1;overflow-y:auto;padding:8px 0}
.ph-nitem{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;transition:background .15s}
.ph-nitem:hover{background:var(--bg3)}
.ph-nitem.unread{background:rgba(0,149,246,.04)}
.ph-nitem-av{width:40px;height:40px;border-radius:50%;background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px}
.ph-nitem-av.ring{background:var(--sg);padding:2px}
.ph-nitem-av-in{width:100%;height:100%;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:16px;border:2px solid var(--bg)}
.ph-nitem-txt{flex:1;font-size:13px;line-height:1.4}
.ph-nitem-time{font-size:11px;color:var(--text3);flex-shrink:0}
.ph-ndot{width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0}
/* Phone internal chat */
.ph-chat-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.ph-chat-note{text-align:center;font-size:11px;color:var(--text3);padding:4px}
.ph-chat-inprow{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0}
.ph-chat-inp{flex:1;background:var(--bg3);border:1px solid var(--border2);border-radius:20px;padding:9px 14px;color:var(--text);outline:none;font-size:13px}
.ph-chat-inp::placeholder{color:var(--text3)}
.ph-chat-send{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.5;transition:opacity .2s}
.ph-chat-send.on{opacity:1}
/* Phone bottom nav */
.pbnavbar{position:absolute;bottom:0;left:0;right:0;height:72px;background:var(--bg);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding-bottom:16px;z-index:5}
.pbnav{padding:8px;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer}
.pbnav.active{color:#fff}
.pbnav.active svg{stroke-width:2.5}
.pclose{position:fixed;top:20px;right:20px;z-index:710;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;border:1px solid rgba(255,255,255,.2);color:#fff;backdrop-filter:blur(8px)}
#mob-toggle{position:fixed;bottom:88px;right:20px;z-index:600;background:var(--bg3);border:1px solid var(--border);border-radius:100px;padding:10px 16px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .2s}
#mob-toggle:hover{background:var(--bg4)}
.mobtoggle-ico{height:16px;width:auto;mix-blend-mode:screen;flex-shrink:0;display:block}

/* Mobile */
#mob-topbar{display:none;position:sticky;top:0;z-index:50;background:rgba(0,0,0,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:12px 16px;flex-shrink:0}
.mob-logo{font-size:22px;font-style:italic;font-weight:700}
.mob-topicons{display:flex;gap:18px;align-items:center}
.mob-icon{position:relative;cursor:pointer;display:flex;align-items:center}
.mob-badge{width:8px;height:8px;border-radius:50%;background:var(--red);position:absolute;top:-2px;right:-2px;border:2px solid var(--bg)}
#mob-feed{display:none;flex-direction:column;width:100%;padding-bottom:72px}
#mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:600;background:rgba(0,0,0,.92);backdrop-filter:blur(10px);border-top:1px solid var(--border);align-items:center;justify-content:space-around;padding:8px 0 20px;height:72px}
.mnbtn{padding:8px 16px;color:var(--text2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s}
.mnbtn.active{color:var(--text)}
#mob-profsec{display:none;position:fixed;top:61px;left:0;right:0;bottom:0;z-index:550;background:var(--bg);overflow-y:auto;padding-bottom:80px}


/* ── PHONE INTERNAL BOTTOM SHEET ── */
/* Phone plus button */
.ph-plus-btn{width:30px;height:30px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s;color:var(--text)}
.ph-plus-btn:hover{background:var(--bg4)}
.ptopbar{position:relative!important}
.ph-logo-center{position:absolute;left:50%;transform:translateX(-50%);font-size:20px;font-style:italic;font-weight:700;pointer-events:none;white-space:nowrap}
.ph-bd{position:absolute;inset:0;background:rgba(0,0,0,.55);z-index:22;opacity:0;pointer-events:none;transition:opacity .2s}
.ph-bd.show{opacity:1;pointer-events:all}
.ph-opts-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--bg3);border-radius:14px 14px 0 0;z-index:23;transform:translateY(100%);transition:transform .3s ease}
.ph-opts-sheet.open{transform:translateY(0)}
.ph-sbar{width:32px;height:3px;background:var(--bg5);border-radius:2px;margin:10px auto 8px}
.ph-sitem{display:flex;align-items:center;gap:12px;padding:14px 20px;font-size:14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.ph-sitem:hover{background:var(--bg4)}
.ph-sitem:last-child{border-bottom:none}
.ph-sitem.danger{color:var(--red)}
/* Mobile topbar centered */
#mob-topbar{position:relative}
.mob-logo-center{position:absolute;left:50%;transform:translateX(-50%);font-size:22px;font-style:italic;font-weight:700;pointer-events:none;white-space:nowrap}
.mob-plus{width:36px;height:36px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s}
.mob-plus:hover{background:var(--bg4)}


/* ── MOBILE REELS (single screen, no scroll) ── */
#mob-reels{
  display:none;position:fixed;
  top:0;left:0;right:0;
  bottom:72px;
  z-index:550;background:#000;
  overflow:hidden;
}
/* show the whole video (no cropping) on mobile; black fills any gap */
#mob-reels .reel-vid{object-fit:contain}
.reel-screen{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.reel-bg{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0a0a1e,#0f3460);
  width:100%;height:100%;padding:40px 20px;text-align:center;
}
.reel-play-ico{font-size:72px;opacity:.3;margin-bottom:20px}
.reel-vid{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.reel-pause-ind{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);width:72px;height:72px;border-radius:50%;background:rgba(0,0,0,.45);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease;z-index:4}
.reel-pause-ind.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.reel-pause-ind svg{margin-left:3px}
.reel-mute{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;backdrop-filter:blur(2px);transition:transform .18s ease,background .2s ease}
.reel-mute:hover{background:rgba(0,0,0,.7)}
.reel-mute:active{transform:scale(.88)}
.reel-mute.reel-mute--pulse{transform:scale(1.2)}
.reel-mute svg{transition:opacity .18s ease}
/* video preview tiles (about grid) */
.vid-prev{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.reel-badge{position:absolute;top:8px;right:8px;width:22px;height:22px;color:#fff;filter:drop-shadow(0 1px 3px rgba(0,0,0,.6));pointer-events:none;z-index:3}
.reel-badge svg{width:100%;height:100%}
.vid-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:3}
.vp-circle{width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.42);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center}
.reel-lbl{font-size:18px;font-weight:600;color:rgba(255,255,255,.75);margin-bottom:8px}
.reel-sub{font-size:13px;color:rgba(255,255,255,.38)}

.reel-info{position:absolute;bottom:24px;left:16px;right:60px}
.reel-info-user{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.reel-av{width:32px;height:32px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:14px;border:1.5px solid #fff}
.reel-uname{font-size:14px;font-weight:600;color:#fff}
/* Raghav profile photo across avatars */
.cav2,.ppav,.psav,.reel-av,.svav{overflow:hidden}
.pavsm img,.sav img,.pav img,.ppav img,.cav2 img,.psav img,.reel-av img,.svav img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.reel-caption{font-size:13px;color:rgba(255,255,255,.7);line-height:1.4}
.reel-swipe-hint{
  position:absolute;bottom:76px;left:50%;transform:translateX(-50%);
  font-size:11px;color:rgba(255,255,255,.28);
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.reel-nomore{
  background:#000;text-align:center;
  flex-direction:column;align-items:center;justify-content:center;
}


/* ── PROFILE ITEM LIGHTBOX ── */
#content-lightbox{
  position:fixed;inset:0;z-index:960;
  background:rgba(0,0,0,.92);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
  padding:20px;
}
#content-lightbox.open{opacity:1;pointer-events:all}
.lb-box{
  position:relative;width:min(560px,100%);
  max-height:88vh;overflow-y:auto;
  border-radius:16px;background:var(--bg2);
  border:1px solid var(--border);
}
.lb-box::-webkit-scrollbar{width:3px}
.lb-box::-webkit-scrollbar-thumb{background:var(--bg4)}
.lb-x-btn{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;cursor:pointer;z-index:10;
  border:1px solid rgba(255,255,255,.15);
  transition:background .2s;color:var(--text);
}
.lb-x-btn:hover{background:rgba(255,255,255,.2)}
/* Make pm-gi and pgi look clickable */
.pm-gi,.pgi{cursor:pointer;transition:opacity .2s}
.pm-gi:hover,.pgi:hover{opacity:.85}

/* Toast */
#toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:var(--bg3);border:1px solid var(--border);padding:10px 20px;border-radius:100px;font-size:13px;font-weight:500;z-index:1100;opacity:0;pointer-events:none;transition:opacity .3s;white-space:nowrap}
#toast.show{opacity:1}
/* Backdrop */
#backdrop{position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .2s}
#backdrop.show{opacity:1;pointer-events:all}

/* Welcome splash */
#splash{position:fixed;inset:0;z-index:3000;background:#000;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .55s ease}
#splash.hide{opacity:0;pointer-events:none}
.splash-inner{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 24px}
.splash-script{font-family:var(--font);font-style:normal;font-weight:500;font-size:clamp(22px,4.5vw,40px);color:#fff;opacity:.92;letter-spacing:.5px;margin-bottom:6px}
.splash-title{font-family:var(--font);font-weight:800;text-transform:uppercase;font-size:clamp(46px,13vw,150px);line-height:.92;letter-spacing:.06em;color:#fff}
.splash-bar{margin-top:26px;width:min(300px,68vw);height:4px;border-radius:100px;background:rgba(255,255,255,.16);overflow:hidden}
.splash-bar-fill{height:100%;width:0;border-radius:100px;background:#fff;animation:splashLoad 1.3s cubic-bezier(.22,.9,.2,1) forwards}
@keyframes splashLoad{0%{width:0}35%{width:62%}65%{width:88%}100%{width:100%}}

/* One-time tutorial overlay — premium product tour */
#tutorial{position:fixed;inset:0;z-index:2900;opacity:0;pointer-events:none;transition:opacity .4s ease;font-family:var(--font)}
#tutorial.show{opacity:1;pointer-events:all}
/* Blur+dim scrim with rectangular holes punched out (set via JS mask) */
.tut-scrim{position:absolute;inset:0;z-index:0;background:radial-gradient(120% 90% at 50% 0%,rgba(20,18,40,.66),rgba(0,0,0,.86));-webkit-backdrop-filter:blur(7px) saturate(.9);backdrop-filter:blur(7px) saturate(.9);-webkit-mask-composite:xor;mask-composite:exclude}

.tut-bar{position:absolute;top:18px;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:4}
.tut-count{position:relative;width:46px;height:46px;display:flex;align-items:center;justify-content:center}
.tut-ring{position:absolute;inset:0;width:46px;height:46px;transform:rotate(-90deg)}
.tut-ring-bg{fill:none;stroke:rgba(255,255,255,.16);stroke-width:3}
.tut-ring-fg{fill:none;stroke:url(#tutGrad);stroke:#0095f6;stroke-width:3;stroke-linecap:round;stroke-dasharray:106.8;stroke-dashoffset:0}
.tut-count span{position:relative;color:#fff;font-size:16px;font-weight:600;font-variant-numeric:tabular-nums;z-index:1}
.tut-x{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:15px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s,transform .25s}
.tut-x:hover{background:rgba(255,255,255,.22);transform:rotate(90deg)}

/* Subtle outline around the clear (unblurred) regions */
.tut-hl{position:absolute;border-radius:18px;pointer-events:none;z-index:1;opacity:0;transition:opacity .45s ease .15s;box-shadow:0 0 0 1.5px rgba(255,255,255,.5)}
#tutorial.show .tut-hl{opacity:1}

/* Coachmark glass cards */
.tut-card{position:absolute;width:min(300px,84vw);background:linear-gradient(165deg,rgba(34,32,48,.92),rgba(20,19,30,.95));border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:16px 18px 17px;box-shadow:0 20px 54px rgba(0,0,0,.6);z-index:2;opacity:0;animation:tutCardIn .55s cubic-bezier(.2,.85,.25,1) forwards}
#tutNoteStories{animation-delay:.25s}
#tutNotePosts{animation-delay:.42s}
@keyframes tutCardIn{0%{opacity:0;transform:translateY(14px) scale(.96)}100%{opacity:1;transform:translateY(0) scale(1)}}
/* Connecting lines drawn from each card to its target (coords set in JS) */
#tutLines{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;overflow:visible;opacity:0;transition:opacity .4s ease .25s;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55))}
#tutorial.show #tutLines{opacity:1}
.tut-card-top{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.tut-ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex:none}
.tut-ic-a{background:linear-gradient(135deg,#f0617a,#ffb24a)}
.tut-ic-b{background:linear-gradient(135deg,#0095f6,#7a5cff)}
.tut-step{font-size:10.5px;letter-spacing:1.6px;font-weight:700;color:rgba(255,255,255,.5)}
.tut-card h4{margin:0 0 5px;font-size:16px;font-weight:700;color:#fff;letter-spacing:-.2px}
.tut-card p{margin:0;font-size:13px;line-height:1.55;font-weight:400;color:rgba(255,255,255,.72)}

/* CTA */
.tut-cta-label{position:absolute;bottom:96px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:12.5px;font-weight:500;letter-spacing:.2px;white-space:nowrap;z-index:3;opacity:0;animation:tutCardIn .5s ease .6s forwards}
.tut-cta{position:absolute;bottom:36px;right:44px;left:auto;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#0095f6,#6c5ce7);color:#fff;font-family:var(--font);font-size:15px;font-weight:600;padding:14px 42px;border-radius:14px;box-shadow:0 10px 30px rgba(0,149,246,.5);z-index:3;opacity:0;animation:tutCtaIn .55s cubic-bezier(.2,.85,.25,1) .62s forwards;transition:filter .2s,transform .2s}
.tut-cta:hover{filter:brightness(1.08);transform:translateY(-2px)}
.tut-cta svg{margin-top:1px}
@keyframes tutCtaIn{0%{opacity:0;transform:translateY(16px) scale(.94)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes tutCtaInM{0%{opacity:0;transform:translateX(-50%) translateY(16px) scale(.94)}100%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}
@media(max-width:900px){
  #tutLines{display:none} /* desktop connector lines hidden on mobile */
  /* stronger, uniform dim + blur so the focus areas clearly stand out */
  .tut-scrim{background:rgba(6,6,10,.92);-webkit-backdrop-filter:blur(13px) saturate(.8);backdrop-filter:blur(13px) saturate(.8)}
  .tut-hl{box-shadow:0 0 0 2px rgba(255,255,255,.78),0 0 22px 4px rgba(0,0,0,.55)}
  .tut-card{width:min(300px,88vw);padding:13px 15px 14px}
  .tut-card h4{font-size:15px}
  .tut-card p{font-size:12.5px}
  /* stories card: sits right of the story, arrow on its LEFT points at it */
  #tutNoteStories{text-align:left}
  #tutNoteStories h4{font-size:14.5px}
  #tutNoteStories p{font-size:12px}
  #tutNoteStories::before{content:'';position:absolute;left:-9px;top:var(--tut-arrow-y,50%);transform:translateY(-50%);width:0;height:0;border-top:9px solid transparent;border-bottom:9px solid transparent;border-right:9px solid rgba(36,34,50,.96)}
  /* posts card: sits below the strip, arrow on its TOP points up */
  #tutNotePosts{text-align:center}
  #tutNotePosts::before{content:'';position:absolute;top:-9px;left:var(--tut-arrow-x,50%);transform:translateX(-50%);width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:9px solid rgba(36,34,50,.96)}
  /* CTA centered at the bottom */
  .tut-cta{left:50%;right:auto;bottom:26px;transform:translateX(-50%);padding:13px 42px;animation-name:tutCtaInM}
  .tut-cta:hover{transform:translateX(-50%) translateY(-2px)}
}
