*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;background:#000;font-family:-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;color:#fff;-webkit-font-smoothing:antialiased}

/* ===== START SCREEN ===== */
#start{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9000;background:#000;transition:opacity .8s}
#start.gone{opacity:0;pointer-events:none}
#start h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;text-align:center;margin-bottom:.5rem;letter-spacing:-.02em}
#start h1 em{color:#fe2c55;font-style:normal}
#start .sub1{font-size:1.1rem;color:#666;margin-bottom:2.5rem}
#start button{padding:14px 40px;border:none;border-radius:50px;background:#fe2c55;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .15s}
#start button:hover{transform:scale(1.05)}

/* Start screen footer */
.start-footer{
  position:absolute;bottom:100px;left:0;right:0;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.start-share{
  display:flex;align-items:center;gap:5px;
  padding:6px 14px!important;border:1px solid #fe2c55!important;border-radius:50px!important;
  background:transparent!important;color:#fe2c55!important;font-size:11px!important;font-weight:500!important;
  cursor:pointer;font-family:inherit;transition:background .2s,color .2s;
}
.start-share:hover{background:rgba(254,44,85,.1)!important;color:#fe2c55!important;transform:none!important}
.start-views{display:flex;align-items:center;gap:4px;font-size:11px;color:#fe2c55;font-variant-numeric:tabular-nums;margin-bottom:25px}
.start-views span{color:#fe2c55;font-weight:600}

/* Pause button — subtle tap target */
.pause-btn{
  position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:8500;
  padding:8px 22px;border:none;border-radius:50px;
  background:transparent;
  color:rgba(255,255,255,.35);font-size:14px;font-weight:600;letter-spacing:1px;
  cursor:pointer;font-family:inherit;
  transition:color .2s;
}
.pause-btn:hover{color:rgba(255,255,255,.6)}

/* Pause overlay — dim area below phone */
.pause-overlay{
  position:fixed;left:0;right:0;bottom:0;height:80px;z-index:8200;
  display:flex;
  align-items:center;justify-content:center;
  cursor:pointer;
}
.pause-text{font-size:13px;font-weight:500;color:rgba(255,255,255,.5);letter-spacing:.3px}
.pause-hint{display:none}

/* ===== TIMER ===== */
.tbar{position:fixed;bottom:0;left:0;right:0;height:3px;z-index:8000;background:#111}
.tbar .fill{height:100%;width:0;background:linear-gradient(90deg,#25f4ee,#fe2c55);transition:width .1s linear}
.tbar .lbl{display:none}

/* ===== PHONE ===== */
.phone{position:fixed;top:calc(50% - 20px);left:50%;transform:translate(-50%,-50%);width:393px;height:852px;max-width:96vw;max-height:88vh;background:#000;border-radius:55px;border:4px solid #1a1a1a;overflow:hidden;z-index:1000;box-shadow:0 0 0 2px #000,0 40px 80px rgba(0,0,0,.6)}
.phone .di{display:none}
.phone .sb{position:absolute;top:0;left:0;right:0;height:54px;z-index:400;display:flex;justify-content:space-between;align-items:flex-start;padding:14px 28px 0;font-size:15px;font-weight:600;color:#fff}
.phone .sb .r{display:flex;align-items:center;gap:5px;font-size:12px}
.phone .sb .bars{display:flex;align-items:flex-end;gap:1px}
.phone .sb .bars i{display:block;width:3px;background:#fff;border-radius:1px}
.phone .hi{position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:134px;height:5px;background:rgba(255,255,255,.2);border-radius:100px;z-index:500}
.phone .scr{position:absolute;inset:0;overflow:hidden}

/* ===== APP LAYERS ===== */
.app{position:absolute;inset:0;transform:translateX(100%);opacity:0;transition:transform .45s cubic-bezier(.32,.72,.32,1),opacity .45s}
.app.on{transform:translateX(0);opacity:1}
.app.off{transform:translateX(-30%);opacity:0}

/* ===== OVERLAYS ===== */
.flash{position:fixed;inset:0;background:#fff;z-index:9999;opacity:0;pointer-events:none}
.flash.go{animation:flashAnim .35s}
@keyframes flashAnim{0%{opacity:.85}100%{opacity:0}}
.toast{position:fixed;bottom:55px;left:50%;transform:translateX(-50%) translateY(20px);background:rgba(28,28,30,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:12px 22px;border-radius:14px;font-size:15px;color:#e5e5e7;z-index:9999;opacity:0;transition:all .35s;white-space:nowrap;display:flex;align-items:center;gap:10px;font-weight:500;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== WHATSAPP ===== */
.wa{background:#0b141a}
.wa-hd{background:#1f2c34;height:96px;display:flex;align-items:flex-end;padding:0 10px 10px;gap:8px}
.wa-hd .bk{color:#00a884;font-size:24px;font-weight:300}
.wa-hd .av{width:40px;height:40px;border-radius:50%;background:#2a3942;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#8696a0}
.wa-hd .inf{flex:1}
.wa-hd .inf h3{font-size:16px;font-weight:500;color:#e9edef}
.wa-hd .inf p{font-size:12px;color:#8696a0}
.wa-hd .acts{display:flex;gap:18px;color:#8696a0;font-size:20px}
.wa-msgs{position:absolute;top:96px;bottom:54px;left:0;right:0;padding:4px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:3px;background-color:#0b141a;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23111b21' fill-opacity='0.6'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.wa-bar{position:absolute;bottom:0;left:0;right:0;height:54px;background:#1f2c34;display:flex;align-items:center;padding:0 6px;gap:6px}
.wa-bar .inp{flex:1;height:40px;background:#2a3942;border-radius:21px;padding:0 10px 0 12px;display:flex;align-items:center;gap:8px;font-size:15px;color:#8696a0}
.wa-bar .inp span{flex:1}
.wa-bar .mic{width:42px;height:42px;border-radius:50%;background:#00a884;display:flex;align-items:center;justify-content:center}

/* ===== CHARACTER AVATARS ===== */
.av-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:-.5px}
.av-big{width:32px;height:32px;font-size:12px}
.av-marco{background:#e9a945}.av-sara{background:#53bdeb}.av-tim{background:#8696f0}
.av-leon{background:#a0d468}.av-tom{background:#ff6b81}.av-lukas{background:#f0c040}
.av-noah{background:#7c8fa6}.av-anon{background:#666}.av-aggro{background:#c0392b}
.av-troll{background:#8e44ad}.av-hype{background:#e67e22}.av-xxl{background:#2ecc71}

/* WA Messages */
.wm{max-width:80%;padding:6px 8px 3px;border-radius:8px;font-size:14.5px;line-height:1.35;color:#e9edef;position:relative;opacity:0;animation:msgIn .2s ease forwards}
.wm.other{background:#202c33;align-self:flex-start;border-top-left-radius:0}
.wm.other::before{content:'';position:absolute;top:0;left:-6px;border-width:0 6px 8px 0;border-style:solid;border-color:transparent #202c33 transparent transparent}
.wm .who{font-size:12.5px;font-weight:500;display:block;margin-bottom:2px}
.wm .meta{font-size:11px;color:rgba(255,255,255,.45);float:right;margin:4px 0 0 8px;display:flex;align-items:center;gap:3px}
.wm-photo{max-width:80%;background:#202c33;border-radius:8px;align-self:flex-start;border-top-left-radius:0;padding:3px;position:relative;opacity:0;animation:msgIn .2s ease forwards}
.wm-photo::before{content:'';position:absolute;top:0;left:-6px;border-width:0 6px 8px 0;border-style:solid;border-color:transparent #202c33 transparent transparent}
.wm-photo .img{width:100%;height:220px;border-radius:6px;overflow:hidden;position:relative;background:#1a1a1a}
.wm-photo .cap{padding:4px 6px 2px;font-size:14.5px;color:#e9edef;line-height:1.35}
.wm-photo .meta{font-size:11px;color:rgba(255,255,255,.45);float:right;margin:4px 0 0 8px;display:flex;align-items:center;gap:3px}
/* WA Sticker */
.wm-sticker{align-self:flex-start;padding:2px 0;position:relative;opacity:0;animation:msgIn .2s ease forwards}
.wm-sticker img{width:120px;height:120px;object-fit:contain;filter:drop-shadow(1.5px 0 0 #fff) drop-shadow(-1.5px 0 0 #fff) drop-shadow(0 1.5px 0 #fff) drop-shadow(0 -1.5px 0 #fff) drop-shadow(2px 0 0 #fff) drop-shadow(-2px 0 0 #fff) drop-shadow(0 2px 0 #fff) drop-shadow(0 -2px 0 #fff)}
.wm-sticker .stk-emoji{position:absolute;bottom:4px;right:4px;font-size:28px;filter:drop-shadow(0 2px 3px rgba(0,0,0,.4))}
.wm-sticker .meta{font-size:11px;color:rgba(255,255,255,.45);margin-top:1px}

.wa-sys{text-align:center;font-size:12.5px;color:#8696a0;padding:6px 12px;background:rgba(32,44,51,.7);border-radius:8px;align-self:center;opacity:0;animation:msgIn .2s ease forwards}
.wa-date{text-align:center;font-size:11.5px;color:#8696a0;padding:5px 12px;background:rgba(32,44,51,.85);border-radius:7px;align-self:center;margin:4px 0 6px}
.wa-typ{align-self:flex-start;background:#202c33;padding:12px 18px;border-radius:8px 8px 8px 0;display:flex;gap:4px;opacity:0;animation:msgIn .2s ease forwards}
.wa-typ i{width:7px;height:7px;background:#8696a0;border-radius:50%;display:inline-block;animation:typDot 1.2s infinite}
.wa-typ i:nth-child(2){animation-delay:.15s}
.wa-typ i:nth-child(3){animation-delay:.3s}
@keyframes typDot{0%,60%,100%{opacity:.3;transform:scale(1)}30%{opacity:1;transform:scale(1.3)}}

/* ===== INSTAGRAM ===== */
.ig{background:#000}
.ig-hd{background:#000;height:90px;display:flex;align-items:flex-end;padding:0 14px 8px;border-bottom:.5px solid #262626}
.ig-hd .bk svg{width:24px;height:24px;fill:none;stroke:#f5f5f5;stroke-width:2}
.ig-hd .bk{margin-right:12px;display:flex}
.ig-hd .avr{width:32px;height:32px;border-radius:50%;background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);padding:2px;margin-right:8px;display:flex;align-items:center;justify-content:center}
.ig-hd .avr i{width:100%;height:100%;border-radius:50%;background:#000;display:block}
.ig-hd .usr{font-size:14px;font-weight:600;flex:1;color:#f5f5f5}
.ig-hd .more{color:#f5f5f5;font-size:20px;letter-spacing:3px}
.ig-body{position:absolute;top:90px;left:0;right:0;bottom:50px;overflow-y:auto}
.ig-img{width:100%;aspect-ratio:1;position:relative;overflow:hidden;background:#1a1a1a}
.ig-acts{padding:10px 14px 4px;display:flex;align-items:center;gap:16px}
.ig-acts svg{width:24px;height:24px;cursor:pointer}
.ig-acts .save{margin-left:auto}
.ig-stats{padding:0 14px 2px}
.ig-stats .lkc{font-size:14px;font-weight:600;color:#f5f5f5}
.ig-stats .allc{font-size:14px;color:#8e8e8e;margin-top:3px;cursor:pointer}
.ig-coms{padding:0 14px 10px}
.ig-c{margin-bottom:4px;font-size:14px;line-height:1.4;color:#a8a8a8;opacity:0;animation:msgIn .2s ease forwards}
.ig-c b{color:#f5f5f5;font-weight:600;margin-right:4px}
.ig-c.vic{color:#ff6b81;background:rgba(255,107,129,.12);border-left:3px solid #ff6b81;padding:8px 10px;border-radius:0 8px 8px 0;margin:6px 0;font-size:14px;opacity:1!important}
.ig-c.vic b{color:#ff6b81}
.ig-views{padding:0 14px 4px;font-size:12px;color:#8e8e8e}
.ig-nav{position:absolute;bottom:0;left:0;right:0;height:50px;background:#000;border-top:.5px solid #262626;display:flex;justify-content:space-around;align-items:center}
.ig-nav svg{width:24px;height:24px;fill:none;stroke:#f5f5f5;stroke-width:1.5}

/* ===== TIKTOK ===== */
.tk{background:#000}
.tk-vid{position:absolute;inset:0;overflow:hidden}
.tk-lbl{position:absolute;top:54px;left:12px;display:flex;align-items:center;gap:6px;font-size:13px;color:rgba(255,255,255,.9);z-index:10}
.tk-lbl svg{width:14px;height:14px;fill:none;stroke:#fff;stroke-width:2}
.tk-side{position:absolute;right:10px;bottom:180px;display:flex;flex-direction:column;align-items:center;gap:22px;z-index:10}
.tk-sb{display:flex;flex-direction:column;align-items:center;gap:3px}
.tk-sb svg{width:28px;height:28px}
.tk-sb .n{font-size:12px;font-weight:600}
.tk-bot{position:absolute;bottom:60px;left:12px;right:70px;z-index:10}
.tk-bot .u{font-size:15px;font-weight:700;margin-bottom:4px}
.tk-bot .d{font-size:13px;color:rgba(255,255,255,.9);line-height:1.5}
.tk-bot .tag{color:#25f4ee}
.tk-cmt{position:absolute;top:100%;left:0;right:0;bottom:0;background:#000;z-index:20;transition:top .4s cubic-bezier(.32,.72,.32,1);pointer-events:none}
.tk-cmt.open{top:35%;border-radius:12px 12px 0 0;display:flex;flex-direction:column;pointer-events:auto}
.tk-cmt .hdr{padding:14px;text-align:center;font-weight:700;font-size:14px;border-bottom:.5px solid #2a2a2a;flex-shrink:0}
.tk-cmt .lst{padding:12px 14px 56px;overflow-y:auto;flex:1;min-height:0}
.tc{display:flex;gap:10px;margin-bottom:16px;opacity:0;animation:msgIn .25s ease forwards}
.tc .av{width:32px;height:32px;border-radius:50%;background:#2a2a2a;flex-shrink:0}
.tc .nm{font-size:13px;font-weight:500;color:#8a8a8a}
.tc .tx{font-size:14px;color:#e9e9e9;margin-top:2px;line-height:1.4}
.tc.vic .nm{color:#ff6b81;font-weight:600}
.tc.vic .tx{color:#ff6b81;background:rgba(255,107,129,.1);padding:6px 10px;border-radius:8px;border-left:3px solid #ff6b81}
.tk-rpt{position:absolute;bottom:110px;left:50%;transform:translateX(-50%);background:rgba(50,50,50,.9);padding:10px 20px;border-radius:10px;font-size:13px;color:#999;z-index:25;opacity:0;animation:msgIn .3s ease forwards}
.tk-nav{position:absolute;bottom:0;left:0;right:0;height:50px;background:#121212;display:flex;justify-content:space-around;align-items:center;z-index:30;border-top:.5px solid #2a2a2a}
.tk-nav .ni{display:flex;flex-direction:column;align-items:center;gap:2px}
.tk-nav .ni svg{width:22px;height:22px}
.tk-nav .ni span{font-size:10px;color:#8a8a8a}
.tk-nav .ni.act span{color:#fff}
.tk-nav .cr{width:44px;height:28px;position:relative;display:flex;align-items:center;justify-content:center}
.tk-nav .cr .bg1{position:absolute;left:0;width:32px;height:100%;background:#25f4ee;border-radius:6px}
.tk-nav .cr .bg2{position:absolute;right:0;width:32px;height:100%;background:#fe2c55;border-radius:6px}
.tk-nav .cr .fg{position:relative;z-index:2;width:32px;height:100%;background:#fff;border-radius:5px;display:flex;align-items:center;justify-content:center}
.tk-nav .cr .fg svg{width:18px;height:18px}

/* ===== HOMESCREEN ===== */
.hs{background:linear-gradient(180deg,#1c1c1e 0%,#000 100%)}
.hs-time{position:absolute;top:65px;left:0;right:0;text-align:center;z-index:2}
.hs-time .t{font-size:76px;font-weight:200;letter-spacing:2px;line-height:1}
.hs-time .d{font-size:16px;color:rgba(255,255,255,.6);margin-top:4px;font-weight:400}
.hs-notifs{position:absolute;top:200px;left:10px;right:10px;bottom:120px;z-index:10;display:flex;flex-direction:column;gap:6px;overflow:hidden}
.hs-n{background:rgba(44,44,46,.95);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);padding:12px 14px;border-radius:14px;display:flex;align-items:center;gap:10px;font-size:14px;opacity:0;animation:notifSlide .3s ease forwards;line-height:1.3;color:#c7c7cc}
.hs-n strong{color:#fff}
.hs-n .ico{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
@keyframes notifSlide{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.hs-dock{position:absolute;bottom:20px;left:10px;right:10px;display:flex;justify-content:center;gap:12px;z-index:5}
.hs-ai{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}
.hs-ai img{width:58px;height:58px;display:block;border-radius:13px}
.hs-ai .nm{font-size:10px;color:rgba(255,255,255,.7)}
.hs-ai .bdg{position:absolute;top:-4px;right:-2px;background:#ff3b30;color:#fff;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;padding:0 5px;z-index:3}

/* ===== MESSAGES APP ===== */
.im{background:#000}
.im-hd{background:#1c1c1e;height:96px;display:flex;align-items:flex-end;padding:0 14px 10px;gap:10px}
.im-hd .bk{color:#007aff;font-size:16px;font-weight:400;display:flex;align-items:center;gap:2px}
.im-hd .bk svg{width:20px;height:20px}
.im-hd .cnt{flex:1;text-align:center}
.im-hd .cnt .nm{font-size:16px;font-weight:600;color:#f5f5f5}
.im-hd .cnt .sub{font-size:12px;color:#8e8e93}
.im-msgs{position:absolute;top:96px;bottom:54px;left:0;right:0;padding:8px 14px;overflow-y:auto;display:flex;flex-direction:column;justify-content:flex-end;gap:6px}
.im-bub{max-width:75%;padding:9px 14px;border-radius:18px;font-size:16px;line-height:1.4;opacity:0;animation:msgIn .3s ease forwards}
.im-bub.sent{background:#007aff;color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.im-bub.received{background:#3a3a3c;color:#fff;align-self:flex-start;border-bottom-left-radius:4px;max-width:75%}
.im-bub.vic{background:rgba(255,107,129,.15);color:#ff6b81;border:1.5px solid rgba(255,107,129,.3);align-self:flex-end;border-bottom-right-radius:4px;font-weight:500}
.im-bar{position:absolute;bottom:0;left:0;right:0;height:54px;background:#1c1c1e;border-top:.5px solid #2c2c2e;display:flex;align-items:center;padding:0 10px;gap:8px}
.im-bar .inp{flex:1;height:36px;border:1px solid #3a3a3c;border-radius:18px;padding:0 14px;display:flex;align-items:center;color:#8e8e93;font-size:15px}
.im-typ{align-self:flex-end;max-width:75%;background:#3a3a3c;padding:12px 18px;border-radius:18px 18px 4px 18px;display:flex;gap:4px;opacity:0;animation:msgIn .2s ease forwards}
.im-typ i{width:7px;height:7px;background:#8e8e93;border-radius:50%;display:inline-block;animation:typDot 1.2s infinite}
.im-typ i:nth-child(2){animation-delay:.15s}
.im-typ i:nth-child(3){animation-delay:.3s}

/* ===== FINAL ===== */
.fin{background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;padding-top:70px;padding-bottom:20px;gap:0}
.fl{font-size:clamp(1.3rem,3.5vw,2.2rem);font-weight:700;text-align:center;line-height:1.5;letter-spacing:-.02em;opacity:0;transform:translateY(16px);transition:opacity 1.8s ease,transform 1.8s ease;margin-bottom:.15em}
.fl.show{opacity:1;transform:translateY(0)}
.fin-spacer{flex:1;min-height:1em;max-height:3em}

/* ===== PHOTO LAYERS ===== */
.real-photo{position:absolute;inset:0;background-image:url('../assets/photo.jpg');background-size:cover;background-position:center top}
.photo-wrap{position:relative;width:100%;height:100%}
.photo-wrap .edits{position:absolute;inset:0;z-index:3;pointer-events:none;font-family:'Comic Sans MS','Chalkduster',cursive}
.photo-wrap .e{position:absolute;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.7);opacity:0;transition:opacity .4s}.e.on{opacity:1}
.photo-wrap .igfr{position:absolute;inset:0;border:3px solid #333;z-index:5;opacity:0;transition:opacity .4s}.igfr.on{opacity:1}
.photo-wrap .igfr::before{content:attr(data-user);position:absolute;top:4px;left:8px;font-family:-apple-system,sans-serif;font-size:10px;font-weight:600;color:#888}
.photo-wrap .igfr::after{content:attr(data-likes);position:absolute;bottom:4px;left:8px;font-family:-apple-system,sans-serif;font-size:9px;color:#888}
.photo-wrap .grain{position:absolute;inset:0;z-index:6;opacity:0;transition:opacity .4s;mix-blend-mode:overlay;background:repeating-linear-gradient(0deg,transparent,transparent 1px,rgba(255,0,0,.03) 1px,transparent 3px)}
.grain.on,.igfr.on{opacity:1}

@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ===== FINALE ELEMENTS ===== */

.fin-msg{
  font-size:13px;color:#8e8e8e;text-align:center;
  line-height:1.5;font-weight:400;
}

/* CTA screen: fullscreen call to action (outside phone frame) */
.cta-screen{
  position:fixed;inset:0;
  z-index:2000;background:#000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:16px;padding:40px 30px 80px;
}

.cta-logo{
  display:block;text-align:center;
  opacity:0;transform:translateY(10px);
  transition:opacity 1.2s ease,transform 1.2s ease;
}
.cta-logo.show{opacity:1;transform:translateY(0)}
.cta-logo img{height:40px;width:auto;filter:brightness(0) invert(1)}

.cta-links{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:0;transform:translateY(10px);
  transition:opacity 1.2s ease .2s,transform 1.2s ease .2s;
}
.cta-links.show{opacity:1;transform:translateY(0)}
.cta-links a{
  display:flex;align-items:center;gap:5px;
  font-size:clamp(.75rem,1.8vw,.85rem);color:rgba(255,255,255,.5);
  text-decoration:none;transition:color .2s;
}
.cta-links a:hover{color:rgba(255,255,255,.8)}
.cta-links svg{flex-shrink:0}

.cta-helpline{
  font-size:clamp(.8rem,2vw,1rem);color:#fe2c55;text-align:center;
  font-weight:600;letter-spacing:.02em;
  opacity:0;transform:translateY(10px);
  transition:opacity 1.2s ease .3s,transform 1.2s ease .3s;
}
.cta-helpline.show{opacity:1;transform:translateY(0)}

.cta-text{
  font-size:clamp(.75rem,1.8vw,.9rem);color:#888;text-align:center;
  line-height:1.6;font-weight:400;
  max-width:340px;
  opacity:0;transform:translateY(10px);
  transition:opacity 1.2s ease .6s,transform 1.2s ease .6s;
}
.cta-text.show{opacity:1;transform:translateY(0)}

/* Buttons + Views inside phone (finale) */
.fin-actions{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  margin-top:10px;
}
.fin-buttons{display:flex;flex-direction:column;gap:10px;align-items:center;width:100%;max-width:260px}
.fin-views{
  display:flex;align-items:center;gap:4px;
  font-size:11px;color:#fe2c55;font-variant-numeric:tabular-nums;
}
.fin-views span{color:#fe2c55;font-weight:600}

/* ===== GLOBAL DISCLAIMER ===== */
.disclaimer{
  position:fixed;bottom:14px;left:0;right:0;
  text-align:center;
  font-size:.6875rem;color:rgba(255,255,255,.55);
  padding:8px 30px 3px;
  border-top:1px solid rgba(255,255,255,.08);
  z-index:9900;
  pointer-events:none;
  line-height:1.35;
}

/* ===== LIMIT PAGE ===== */
#limitPage{
  position:fixed;inset:0;
  display:none;
  flex-direction:column;align-items:center;justify-content:center;
  z-index:9000;background:#000;gap:30px;
}
#limitPage.show{display:flex}
.limit-phone{
  width:360px;max-width:90vw;
  background:rgba(28,28,30,.6);
  border-radius:30px;border:2px solid #1a1a1a;
  padding:40px 24px 36px;
  display:flex;flex-direction:column;align-items:center;gap:24px;
}
.limit-notifs{
  width:100%;display:flex;flex-direction:column;gap:6px;
}
.limit-n{
  background:rgba(44,44,46,.8);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:10px 12px;border-radius:12px;
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:#999;line-height:1.3;
  opacity:0;animation:notifSlide .4s ease forwards;
}
.limit-n strong{color:#e5e5e7}
.limit-ico{
  width:26px;height:26px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;flex-shrink:0;
}
.limit-msg{
  text-align:center;display:flex;flex-direction:column;gap:12px;
}
.limit-title{
  font-size:1.3rem;font-weight:700;color:#fff;line-height:1.3;
}
.limit-sub{
  font-size:13px;color:#8e8e8e;line-height:1.6;
}
.limit-sub2{
  font-size:12px;color:#555;line-height:1.5;font-style:italic;
}

/* ===== FOOTER BUTTONS (inside phone finale) ===== */

.footer-share{
  display:flex;align-items:center;justify-content:center;gap:5px;
  padding:12px 18px;width:100%;
  border:none;border-radius:50px;
  background:#fe2c55;
  color:#fff;font-size:clamp(11px,2.8vw,13px);font-weight:600;
  cursor:pointer;font-family:inherit;
  transition:background .2s,transform .15s;
  white-space:nowrap;
}
.footer-share:hover{background:#e0264d;transform:scale(1.03)}
.footer-share:active{transform:scale(.97)}

.footer-replay{
  display:flex;align-items:center;justify-content:center;gap:5px;
  padding:12px 18px;width:100%;
  border:1px solid #fe2c55;border-radius:50px;
  background:transparent;
  color:#fe2c55;font-size:clamp(11px,2.8vw,13px);font-weight:500;
  cursor:pointer;font-family:inherit;
  transition:background .2s,transform .15s;
  white-space:nowrap;
}
.footer-replay:hover{background:rgba(255,255,255,.08);transform:scale(1.03)}
.footer-replay:active{transform:scale(.97)}

/* ===== IMPRESSUM LINK ===== */
.impr-link-bar{
  position:fixed;bottom:3px;left:0;right:0;
  text-align:center;padding:0;
  z-index:9901;pointer-events:none;
}
.impr-link{color:#fe2c55;cursor:pointer;pointer-events:auto;text-decoration:none;font-size:.75rem;font-weight:500;margin:10px 0}
.impr-link:hover{text-decoration:underline}

/* ===== IMPRESSUM MODAL ===== */
.imp-modal{
  position:fixed;inset:0;
  background:rgba(0,0,0,.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  z-index:99999;
  display:none;align-items:center;justify-content:center;
}
.imp-modal.show{display:flex}

/* Phone frame for impressum */
.imp-phone{
  width:393px;height:750px;
  max-width:92vw;max-height:88vh;
  background:#000;
  border-radius:50px;border:3px solid #222;
  overflow:hidden;position:relative;
  box-shadow:0 30px 60px rgba(0,0,0,.5);
}
.imp-statusbar{
  height:50px;display:flex;justify-content:space-between;align-items:flex-end;
  padding:0 28px 6px;font-size:14px;font-weight:600;color:#fff;
  background:#000;position:sticky;top:0;z-index:2;
}
.imp-scroll{
  height:calc(100% - 50px);overflow-y:auto;padding:0 20px 30px;
  -webkit-overflow-scrolling:touch;
}
.imp-scroll h2{
  color:#fff;font-size:1.6rem;font-weight:700;margin:16px 0 4px;
}
.imp-subtitle{color:#666;font-size:.9rem;margin-bottom:20px}

.imp-notice{
  padding:14px 16px;
  background:rgba(254,44,85,.08);
  border:1px solid rgba(254,44,85,.2);
  border-radius:12px;
  margin-bottom:18px;text-align:center;
}
.imp-notice p{color:#fe2c55;font-size:.82rem;line-height:1.55;margin:0}

.imp-block{
  background:#111;
  border:1px solid #222;
  border-radius:12px;
  padding:14px 16px;
  margin-bottom:12px;
}
.imp-block p{font-size:.9rem;line-height:1.55;color:#999;margin-bottom:3px}
.imp-block p:last-child{margin-bottom:0}
.imp-block strong{color:#e5e5e7}
.imp-block a{color:#fe2c55;text-decoration:none}
.imp-block a:hover{text-decoration:underline}

.imp-close-btn{
  display:block;margin:20px auto 0;
  padding:12px 36px;border:none;border-radius:50px;
  background:#fe2c55;color:#fff;
  font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;
  transition:transform .15s;
}
.imp-close-btn:hover{transform:scale(1.03)}
.imp-close-btn:active{transform:scale(.97)}

.imp-home-indicator{
  width:134px;height:5px;
  background:rgba(255,255,255,.2);border-radius:100px;
  margin:16px auto 0;
}

/* ===== INITIAL HIDDEN ===== */
.hidden{display:none}

/* ===== STATUSBAR DETAILS ===== */
.sb-bars i:nth-child(1){height:4px}
.sb-bars i:nth-child(2){height:7px}
.sb-bars i:nth-child(3){height:10px}
.sb-bars i:nth-child(4){height:13px}
.sb-5g{font-size:11px}
.imp-statusbar-label{font-size:12px;color:#888}
.tk-nav-active{color:#fff}

/* ===== LIMIT PAGE ICONS ===== */
.limit-ico-wa{background:#00a884}
.limit-ico-heart{background:#fe2c55}
.limit-ico-cam{background:#cc2366}
.limit-ico-tk{background:#fe2c55}
.limit-ico-phone{background:#48484a}
.limit-n:nth-child(1){animation-delay:0s}
.limit-n:nth-child(2){animation-delay:.4s}
.limit-n:nth-child(3){animation-delay:.8s}
.limit-n:nth-child(4){animation-delay:1.2s}
.limit-n:nth-child(5){animation-delay:1.6s}

/* ===== PHOTO OVERLAY POSITIONS ===== */
/* Layer 2: Instagram edits */
.e2-emoji-top{top:6%;left:50%;transform:translateX(-50%);font-size:2.2rem}
.e2-text-look{top:22%;left:8%;font-size:.95rem;color:#fff;transform:rotate(-12deg);font-style:italic;text-shadow:0 2px 4px rgba(0,0,0,.8)}
.e2-poop{top:18%;right:8%;font-size:2rem}
.e2-ugly{bottom:30%;left:5%;font-size:1.5rem;color:#ff1a1a;transform:rotate(-8deg);font-weight:900;letter-spacing:.05em}
.e2-never{bottom:15%;right:5%;font-size:.95rem;color:#ffee00;transform:rotate(6deg)}
/* Layer 3: TikTok edits */
.e3-exposed{top:3%;left:50%;transform:translateX(-50%);font-size:1rem;color:#fff;font-weight:800;letter-spacing:.1em;text-shadow:0 0 8px rgba(0,0,0,.9);background:rgba(254,44,85,.7);padding:2px 10px;border-radius:4px}
.e3-pov{top:32%;left:50%;transform:translateX(-50%) rotate(2deg);font-size:1.1rem;color:#fff;font-weight:700;text-shadow:0 2px 6px rgba(0,0,0,.9)}
.e3-tags{bottom:25%;left:3%;font-size:.85rem;color:#25f4ee;transform:rotate(-5deg)}
.e3-emoji-bot{bottom:10%;left:50%;transform:translateX(-50%);font-size:1.3rem}
.e3-bozo{top:14%;right:3%;font-size:.8rem;color:#fe2c55;transform:rotate(10deg);font-weight:700}

/* ===== WA CHARACTER COLORS (who label) ===== */
.who-marco{color:#e9a945}
.who-sara{color:#53bdeb}
.who-tim{color:#8696f0}
.who-leon{color:#a0d468}
.wa-check{color:#53bdeb}

/* ===== HOMESCREEN NOTIFICATION ICONS ===== */
.hs-ico-wa{background:#00a884}
.hs-ico-heart{background:#fe2c55}
.hs-ico-cam{background:#cc2366}
.hs-ico-phone{background:#48484a}

/* ===== IG AVATAR INLINE ===== */
.ig-av-inline{display:inline-flex;vertical-align:middle;margin-right:5px}

/* ===== TK STICKER (in comments) ===== */
.tk-sticker-img{width:80px;height:80px;object-fit:contain;filter:drop-shadow(1px 0 0 #fff) drop-shadow(-1px 0 0 #fff) drop-shadow(0 1px 0 #fff) drop-shadow(0 -1px 0 #fff)}
.tk-sticker-wrap{position:relative;width:80px;height:80px;margin-top:4px}
.tk-sticker-lbl{position:absolute;bottom:2px;left:50%;transform:translateX(-50%) rotate(-8deg);font-size:12px;font-weight:900;color:#ff1a1a;text-shadow:0 0 4px rgba(0,0,0,.9),2px 2px 0 #000,-1px -1px 0 #000;letter-spacing:.08em}

/* ===== CLIPBOARD TEXTAREA (offscreen) ===== */
.sr-only-input{position:fixed;top:0;left:0;width:1px;height:1px;opacity:0.01}

/* ===== MOBILE ===== */
@media (max-width:500px){
  .phone{max-height:85vh!important;top:calc(50% - 20px)!important}
  .start-footer{bottom:110px}
  .start-share{padding:4px 10px!important;font-size:10px!important}
  .start-views{margin-bottom:15px}
  .disclaimer{font-size:.55rem;padding:2px 16px;bottom:16px}
  .impr-link-bar{bottom:4px}
  .impr-link{font-size:.7rem}
  .fin-msg{font-size:11px}
  .footer-share{padding:8px 14px;font-size:11px}
  .footer-replay{padding:8px 14px;font-size:11px}
  .hs-notifs{top:180px;bottom:100px}
  .hs-dock{bottom:16px;gap:10px}
  .hs-ai img{width:54px;height:54px;border-radius:12px}
  .imp-phone{max-height:72vh;max-width:85vw;border-radius:32px;border-width:2px}
  .imp-phone .imp-scroll{padding:0 14px 20px}
  .imp-phone .imp-scroll h2{font-size:1.2rem;margin:12px 0 4px}
  .imp-statusbar{height:40px;padding:0 22px 5px;font-size:13px}
  .imp-block{padding:12px 14px;margin-bottom:10px}
  .imp-block p{font-size:.8rem}
  .imp-notice{padding:12px 14px;margin-bottom:14px}
  .imp-notice p{font-size:.76rem}
  .imp-close-btn{padding:10px 30px;font-size:.85rem;margin-top:14px}
  .imp-home-indicator{margin:12px auto 0;width:100px;height:4px}
}
