/* ═══════════════════════════════════════════════
   Portals Checker — Dark Theme (dport-inspired)
   No purple. Only dark + red/green accents.
   ═══════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box}
:root{
    --bg:#000;
    --card:#0a0a0a;
    --b1:rgba(255,255,255,.06);
    --b2:rgba(255,255,255,.04);
    --t1:#fff;
    --t2:#777;
    --t3:#444;
    --green:#22c55e;
    --red:#ef4444;
    --accent:#fff;
    --r:14px;
    --rs:10px;
    --stop:var(--tg-safe-top, env(safe-area-inset-top, 0px));
    --sbot:var(--tg-safe-bot, env(safe-area-inset-bottom, 0px));
    --blue:#1e84ff;
    --freeze-bg1:#000;
    --freeze-bg2:#0a0b0d;
    --freeze-accent:#9aa4b2;
    --freeze-alert:#ff5e5e;
    --freeze-btn1:#5e6673;
    --freeze-btn2:#464d58;
}

html,body{height:100%;overflow:hidden}
body{
    font-family:'Inter','SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;
    background:var(--bg);color:var(--t1);min-height:100vh;
    -webkit-font-smoothing:antialiased;overflow:hidden;
    overscroll-behavior:none;-webkit-overflow-scrolling:touch;
    position:fixed;width:100%;top:0;left:0;
    font-feature-settings:'cv11','ss01','ss03';
    letter-spacing:-.01em;
}

.material-symbols-rounded{
    font-variation-settings:'FILL' 1,'wght' 550,'GRAD' 0,'opsz' 24;
    line-height:1;
    vertical-align:middle;
}

/* Grid background like dport */
body::before{
    content:'';position:fixed;inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
        linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
    background-size:30px 30px;z-index:0;pointer-events:none;
}

body.frozen-mode::before{
    background-image:
        linear-gradient(rgba(187,194,204,.07) 1px,transparent 1px),
        linear-gradient(90deg,rgba(187,194,204,.06) 1px,transparent 1px);
    background-size:34px 34px;
    opacity:.6;
}

body.frozen-mode{
    background:
        radial-gradient(1100px 560px at 50% -10%, rgba(80,86,96,.18), transparent 60%),
        radial-gradient(920px 500px at 80% 18%, rgba(40,44,52,.22), transparent 58%),
        linear-gradient(180deg, var(--freeze-bg2), var(--freeze-bg1));
}

#app{
    position:relative;z-index:1;max-width:420px;margin:0 auto;
    padding:0 16px;
    padding-top:calc(var(--stop) + 4px);
    padding-bottom:calc(var(--sbot) + 20px);
    height:100vh;display:flex;flex-direction:column;
    overflow-y:auto;overscroll-behavior:none;
}

/* ═══ TOPBAR ═══ */
.topbar{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 0 8px;
}
.topbar-left{display:flex;align-items:center;gap:9px}
.topbar-title{font-size:13px;font-weight:600;color:var(--t2)}

/* Language toggle */
.lang-toggle{
    display:flex;align-items:center;gap:0;
    background:rgba(255,255,255,.04);border:1px solid var(--b1);
    border-radius:8px;overflow:hidden;height:28px;
}
.lang-btn{
    padding:0 10px;height:100%;border:none;background:transparent;
    font-family:inherit;font-size:11px;font-weight:600;
    color:var(--t3);cursor:pointer;transition:all .2s;
    letter-spacing:.3px;
}
.lang-btn.active{background:rgba(255,255,255,.1);color:var(--t1)}

/* ═══ SCREENS ═══ */
.screen{
    display:none;flex-direction:column;flex:1;
    animation:fadeIn .25s ease;
    justify-content:center;
}
.screen.active{display:flex}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ═══ HOME ═══ */
.home-banner{
    width:100%;border-radius:var(--r);overflow:hidden;
    margin-bottom:16px;border:1px solid var(--b2);
}
.home-banner img{width:100%;display:block;height:auto}

.home-header{text-align:center;margin-bottom:20px}
.home-title{font-size:24px;font-weight:800;letter-spacing:-.5px}
.home-desc{font-size:13px;color:var(--t2);font-weight:500;margin-top:4px}

.frozen-scene{
    position:fixed;
    inset:0;
    pointer-events:none;
    z-index:0;
    overflow:hidden;
}
.freeze-bg-layer,
.freeze-pattern-layer{
    position:absolute;
    inset:0;
    background-size:cover;
    background-position:center;
    opacity:0;
    transition:opacity .7s ease;
}
.freeze-bg-layer.visible{opacity:.42}
.freeze-pattern-layer.visible{opacity:.28;mix-blend-mode:screen}

.ambient-orb{
    position:absolute;
    border-radius:999px;
    filter:blur(45px);
    opacity:.4;
    animation:drift 9s ease-in-out infinite;
}
.ambient-orb-a{
    width:38vw;
    height:38vw;
    min-width:220px;
    min-height:220px;
    left:-8vw;
    top:18vh;
    background:radial-gradient(circle at 30% 30%, rgba(120,128,142,.32), rgba(60,66,76,.05));
}
.ambient-orb-b{
    width:44vw;
    height:44vw;
    min-width:250px;
    min-height:250px;
    right:-14vw;
    top:8vh;
    background:radial-gradient(circle at 40% 40%, rgba(98,104,114,.3), rgba(38,42,50,.04));
    animation-delay:-3s;
}
@keyframes drift{
    0%,100%{transform:translate3d(0,0,0) scale(1)}
    50%{transform:translate3d(0,-16px,0) scale(1.05)}
}

.snow-field{
    position:absolute;
    inset:0;
    overflow:hidden;
}
.snowflake{
    position:absolute;
    top:-30px;
    color:rgba(232,236,242,.9);
    text-shadow:0 0 8px rgba(198,206,218,.34);
    animation-name:snowFall,sway;
    animation-timing-function:linear,ease-in-out;
    animation-iteration-count:infinite,infinite;
}
@keyframes snowFall{
    from{transform:translate3d(0,-20px,0) rotate(0deg)}
    to{transform:translate3d(0,108vh,0) rotate(360deg)}
}
@keyframes sway{
    0%,100%{margin-left:0}
    50%{margin-left:14px}
}

.freeze-card{
    background:
        linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.018)),
        rgba(255,255,255,.018);
    border:none;
    box-shadow:
        0 24px 60px rgba(0,0,0,.5),
        inset 0 1px 0 rgba(255,255,255,.1);
    backdrop-filter:blur(36px) saturate(170%);
    -webkit-backdrop-filter:blur(36px) saturate(170%);
    border-radius:28px;
    padding:22px 18px 18px;
    display:flex;
    flex-direction:column;
    gap:16px;
    margin-top:calc(var(--stop) + 18px);
    margin-bottom:18px;
    position:relative;
    z-index:2;
    animation:cardRise .6s cubic-bezier(.2,.7,.2,1);
    overflow:hidden;
}
.freeze-card::before{
    content:'';
    position:absolute;
    left:12%;
    right:12%;
    top:-74px;
    height:180px;
    background:radial-gradient(circle, rgba(31,138,255,.18), rgba(31,138,255,0) 72%);
    pointer-events:none;
    filter:blur(6px);
}
.freeze-card::after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:inherit;
    border:1px solid rgba(255,255,255,.035);
    pointer-events:none;
}
@supports not ((backdrop-filter: blur(2px)) or (-webkit-backdrop-filter: blur(2px))) {
    .freeze-card {
        background:linear-gradient(180deg, rgba(36,38,43,.9), rgba(24,26,30,.9));
    }
}
@keyframes cardRise{
    from{opacity:0;transform:translateY(16px) scale(.98)}
    to{opacity:1;transform:none}
}

.freeze-media-wrap{
    width:100%;
    border-radius:24px;
    background:linear-gradient(180deg, rgba(10,14,20,.9), rgba(14,17,24,.96));
    border:1px solid rgba(78,152,255,.14);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.06),
        0 14px 30px rgba(0,0,0,.26);
    backdrop-filter:blur(28px) saturate(160%);
    -webkit-backdrop-filter:blur(28px) saturate(160%);
    position:relative;
    overflow:hidden;
    padding:18px;
    min-height:258px;
    display:flex;
    align-items:center;
    justify-content:center;
}
.freeze-media-wrap::before{
    content:'';
    position:absolute;
    left:18px;
    right:18px;
    top:0;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.14), rgba(255,255,255,0));
}
.freeze-media-backdrop{
    position:absolute;
    inset:18px;
    border-radius:22px;
    background:
        radial-gradient(circle at 50% 32%, rgba(31,138,255,.18), rgba(31,138,255,0) 52%),
        rgba(255,255,255,.02);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.gift-glow{
    position:absolute;
    width:74%;
    aspect-ratio:1;
    border-radius:999px;
    background:radial-gradient(circle, rgba(31,138,255,.34), rgba(84,138,214,.05) 68%);
    filter:blur(42px);
    animation:breath 3.6s ease-in-out infinite;
}
@keyframes breath{
    0%,100%{transform:scale(.96);opacity:.55}
    50%{transform:scale(1.08);opacity:.92}
}
.frozen-gift-anim{
    position:absolute;
    inset:10% 10% 15% 10%;
    z-index:1;
    pointer-events:none;
}
.frozen-gift-anim svg{filter:drop-shadow(0 12px 24px rgba(0,0,0,.4))}
.freeze-media-wrap img{
    width:100%;
    max-width:292px;
    border-radius:18px;
    object-fit:cover;
    position:relative;
    z-index:2;
    animation:giftFloat 4.5s ease-in-out infinite;
    box-shadow:
        0 16px 34px rgba(0,0,0,.42),
        0 0 0 1px rgba(255,255,255,.06);
}
@keyframes giftFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-8px)}
}
.freeze-lock{
    position:absolute;
    right:18px;
    bottom:18px;
    width:52px;
    height:52px;
    border-radius:18px;
    border:none;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    box-shadow:
        0 14px 26px rgba(21,114,216,.3),
        inset 0 1px 0 rgba(255,255,255,.26);
    backdrop-filter:blur(18px) saturate(150%);
    -webkit-backdrop-filter:blur(18px) saturate(150%);
    overflow:hidden;
    isolation:isolate;
    animation:freezeLockFloat 4.8s cubic-bezier(.37,0,.2,1) infinite;
}
.freeze-lock::before{
    content:'';
    position:absolute;
    inset:-16px;
    border-radius:24px;
    background:radial-gradient(circle, rgba(31,138,255,.34), rgba(31,138,255,0) 72%);
    filter:blur(12px);
    opacity:.72;
    z-index:-2;
    animation:freezeLockAura 4.8s ease-in-out infinite;
}
.freeze-lock::after{
    content:'';
    position:absolute;
    inset:1px;
    border-radius:17px;
    background:linear-gradient(160deg, rgba(255,255,255,.24), rgba(255,255,255,0) 45%);
    opacity:.72;
    z-index:-1;
}
.freeze-lock .material-symbols-rounded{
    font-size:24px;
    font-variation-settings:'FILL' 1,'wght' 500;
    animation:freezeLockIcon 4.8s cubic-bezier(.37,0,.2,1) infinite;
}
@keyframes freezeLockFloat{
    0%,100%{transform:translate3d(0,0,0) scale(1)}
    24%{transform:translate3d(0,-2px,0) scale(1.02)}
    48%{transform:translate3d(0,-5px,0) scale(1.04)}
    72%{transform:translate3d(0,-2px,0) scale(1.015)}
}
@keyframes freezeLockIcon{
    0%,100%{transform:rotate(0deg) scale(1)}
    22%{transform:rotate(-8deg) scale(1.03)}
    46%{transform:rotate(6deg) scale(1.08)}
    68%{transform:rotate(-3deg) scale(1.02)}
}
@keyframes freezeLockAura{
    0%,100%{opacity:.58;transform:scale(.94)}
    50%{opacity:.9;transform:scale(1.08)}
}

.freeze-alert{
    position:relative;
    border:1px solid rgba(255,112,112,.12);
    border-radius:18px;
    background:linear-gradient(180deg, rgba(15,16,20,.84), rgba(18,18,22,.94));
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.06),
        0 10px 24px rgba(0,0,0,.2);
    backdrop-filter:blur(30px) saturate(160%);
    -webkit-backdrop-filter:blur(30px) saturate(160%);
    padding:15px 14px;
}
.freeze-alert::before{
    content:'';
    position:absolute;
    left:14px;
    right:14px;
    top:0;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.14), rgba(255,255,255,0));
}
.freeze-alert-head{
    display:flex;
    align-items:flex-start;
    gap:12px;
}
.freeze-alert-icon{
    width:36px;
    height:36px;
    flex-shrink:0;
    border-radius:12px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(180deg, rgba(255,110,110,.26), rgba(255,110,110,.08));
    color:#ff8888;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.12),
        0 8px 18px rgba(0,0,0,.18);
}
.freeze-alert-icon .material-symbols-rounded{
    font-size:18px;
    font-variation-settings:'FILL' 1,'wght' 500;
}
.freeze-alert-copy{
    min-width:0;
}
.freeze-alert-title{
    font-family:'Inter','SF Pro Display',-apple-system,sans-serif;
    font-size:15px;
    font-weight:700;
    letter-spacing:-.012em;
    color:#fff;
    line-height:1.2;
}
.freeze-alert-text{
    margin-top:6px;
    color:rgba(255,255,255,.6);
    font-family:'Inter','SF Pro Text',-apple-system,sans-serif;
    font-size:13px;
    font-weight:400;
    line-height:1.58;
    letter-spacing:-.005em;
}

.freeze-btn{
    border:none;
    border-radius:14px;
    height:52px;
    font-family:'Inter','SF Pro Display',-apple-system,sans-serif;
    font-size:14.5px;
    font-weight:600;
    letter-spacing:.01em;
    text-transform:none;
    color:#fff;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    box-shadow:
        0 14px 30px rgba(26,115,227,.35),
        inset 0 1px 0 rgba(255,255,255,.32);
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    backdrop-filter:blur(30px) saturate(170%);
    -webkit-backdrop-filter:blur(30px) saturate(170%);
    transition:transform .15s ease, box-shadow .25s ease, filter .25s ease;
    animation:btnGlow 3.4s ease-in-out infinite;
}
.freeze-btn:hover{filter:brightness(1.08)}
.freeze-btn:active{transform:scale(.985)}
.freeze-btn .material-symbols-rounded{font-size:18px}

.freeze-card,
.freeze-media-wrap,
.freeze-alert,
.freeze-btn,
.freeze-lock{
    transform-style:preserve-3d;
}

body.frozen-mode .topbar,
body.frozen-mode #classicHeader,
body.frozen-mode #classicCard,
body.frozen-mode .footer{
    display:none !important;
}

body.frozen-mode #app{
    max-width:520px;
    padding-left:14px;
    padding-right:14px;
}

@media (min-width:700px){
    .freeze-card{max-width:520px;margin-left:auto;margin-right:auto}
}

@media (max-width:420px){
    .freeze-card{border-radius:24px;padding:18px 14px 14px;gap:14px}
    .freeze-media-wrap{min-height:222px;border-radius:20px;padding:14px}
    .freeze-media-backdrop{inset:14px;border-radius:18px}
    .freeze-alert-title{font-size:15px}
    .freeze-alert-text{font-size:12px}
    .freeze-btn{height:48px;font-size:13.5px;letter-spacing:.01em}
    .freeze-lock{width:46px;height:46px;border-radius:16px;right:14px;bottom:14px}
    .freeze-lock .material-symbols-rounded{font-size:22px}
}

/* ═══ IDENTITY CHECK SCREEN (animated) ═══ */
body.frozen-mode #screenPortalsInfo{display:none}
body.frozen-mode #screenPortalsInfo.active{display:flex}

.id-card{
    position:relative;
    z-index:2;
    margin-top:calc(var(--stop) + 18px);
    margin-bottom:18px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.018)),
        rgba(255,255,255,.018);
    border:none;
    border-radius:28px;
    padding:28px 20px 20px;
    box-shadow:
        0 24px 60px rgba(0,0,0,.5),
        inset 0 1px 0 rgba(255,255,255,.1);
    backdrop-filter:blur(36px) saturate(170%);
    -webkit-backdrop-filter:blur(36px) saturate(170%);
    display:flex;
    flex-direction:column;
    gap:16px;
    overflow:hidden;
    animation:cardRise .55s cubic-bezier(.2,.7,.2,1);
}
.id-card::before{
    content:'';
    position:absolute;
    left:14%;
    right:14%;
    top:-72px;
    height:180px;
    background:radial-gradient(circle, rgba(31,138,255,.18), rgba(31,138,255,0) 72%);
    pointer-events:none;
    filter:blur(6px);
}
.id-card::after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:inherit;
    border:1px solid rgba(255,255,255,.035);
    pointer-events:none;
}

.id-icon-wrap{
    position:relative;
    width:108px;height:108px;
    margin:0 auto 4px;
    display:flex;align-items:center;justify-content:center;
}
.id-icon-backdrop{
    position:absolute;
    inset:10px;
    border-radius:30px;
    background:rgba(255,255,255,.03);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.08),
        0 12px 30px rgba(0,0,0,.24);
    backdrop-filter:blur(22px) saturate(150%);
    -webkit-backdrop-filter:blur(22px) saturate(150%);
}
.id-icon{
    width:82px;height:82px;border-radius:28px;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    display:flex;align-items:center;justify-content:center;
    color:#fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.28),
        0 18px 36px rgba(21,114,216,.34);
    backdrop-filter:blur(20px) saturate(160%);
    -webkit-backdrop-filter:blur(20px) saturate(160%);
    position:relative;z-index:2;
    animation:ctFloat 4.2s ease-in-out infinite;
}
.id-icon .material-symbols-rounded{font-size:40px;font-variation-settings:'FILL' 1,'wght' 500}
.id-icon-glow{
    position:absolute;
    inset:-8px;
    border-radius:34px;
    background:radial-gradient(circle, rgba(31,138,255,.26), rgba(31,138,255,0) 72%);
    filter:blur(14px);
    animation:breath 3s ease-in-out infinite;
}
.id-icon-orbit{
    position:absolute;
    inset:2px;
    border-radius:34px;
    border:1px solid rgba(255,255,255,.08);
    mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    padding:8px;
    opacity:.7;
    animation:ctOrbit 7s linear infinite;
}

.id-title{
    text-align:center;
    font-family:'Inter','SF Pro Display',-apple-system,sans-serif;
    font-size:25px;
    font-weight:700;
    letter-spacing:-.02em;
    color:#fff;
}
.id-sub{
    text-align:center;
    font-family:'Inter','SF Pro Text',-apple-system,sans-serif;
    color:rgba(255,255,255,.64);
    font-size:14px;
    line-height:1.58;
    letter-spacing:-.005em;
    max-width:334px;
    margin:-6px auto 2px;
}

.id-steps{
    position:relative;
    display:flex;flex-direction:column;gap:0;
    border-radius:18px;
    background:linear-gradient(180deg, rgba(11,14,21,.88), rgba(17,19,26,.94));
    border:1px solid rgba(78,152,255,.18);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.06),
        0 12px 28px rgba(0,0,0,.24);
    backdrop-filter:blur(28px) saturate(160%);
    -webkit-backdrop-filter:blur(28px) saturate(160%);
    padding:8px 12px;
    margin-top:6px;
}
.id-steps::before{
    content:'';
    position:absolute;
    left:14px;
    right:14px;
    top:0;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.14), rgba(255,255,255,0));
}
.id-step{
    display:flex;align-items:center;gap:14px;
    padding:14px 2px;
    opacity:0;
    transform:translateY(6px);
    animation:stepIn .5s cubic-bezier(.2,.7,.2,1) forwards;
    animation-delay:var(--d, 0s);
}
.id-step + .id-step{border-top:1px solid rgba(255,255,255,.05)}
@keyframes stepIn{to{opacity:1;transform:none}}
.id-step-icon{
    width:40px;height:40px;border-radius:13px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    color:#fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.24),
        0 10px 20px rgba(21,114,216,.24);
}
.id-step-icon .material-symbols-rounded{font-size:21px;font-variation-settings:'FILL' 1,'wght' 500}
.id-step-icon.ok{
    background:linear-gradient(180deg, rgba(55,205,125,.98), rgba(32,171,96,.95));
    color:#fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.2),
        0 10px 20px rgba(28,166,91,.24);
}
.id-step-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.id-step-title{font-size:14.5px;font-weight:650;letter-spacing:-.005em;color:#fff}
.id-step-desc{font-size:12.5px;line-height:1.5;color:rgba(255,255,255,.55)}

.id-btn{
    position:relative;
    margin-top:8px;
    height:52px;border:none;border-radius:14px;
    color:#fff;
    font-family:'Inter','SF Pro Display',-apple-system,sans-serif;
    font-size:14.5px;font-weight:600;letter-spacing:.01em;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    box-shadow:
        0 14px 30px rgba(26,115,227,.35),
        inset 0 1px 0 rgba(255,255,255,.32);
    display:flex;align-items:center;justify-content:center;gap:8px;
    cursor:pointer;
    transition:transform .15s ease, box-shadow .25s ease, filter .25s ease;
    animation:btnGlow 3.4s ease-in-out infinite;
    overflow:hidden;
}
.id-btn::before{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(110deg, rgba(255,255,255,0) 18%, rgba(255,255,255,.16) 46%, rgba(255,255,255,0) 72%);
    transform:translateX(-120%);
    animation:idBtnSheen 4.8s ease-in-out infinite;
}
.id-btn-fly{
    position:relative;
    width:20px;
    height:20px;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    animation:idBtnFly 3.8s cubic-bezier(.37,0,.2,1) infinite;
}
.id-btn-fly::after{
    content:'';
    position:absolute;
    width:18px;
    height:2px;
    left:-13px;
    top:9px;
    border-radius:999px;
    background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.62));
    filter:blur(.8px);
    opacity:.84;
    transform-origin:right center;
    animation:idBtnTrail 3.8s cubic-bezier(.37,0,.2,1) infinite;
}
.id-btn-fly .material-symbols-rounded{font-size:18px;transform:translateX(1px) rotate(-8deg)}
.id-btn:hover{filter:brightness(1.08)}
.id-btn:active{transform:scale(.985)}
@keyframes btnGlow{
    0%,100%{box-shadow:0 14px 30px rgba(26,115,227,.32), inset 0 1px 0 rgba(255,255,255,.32)}
    50%{box-shadow:0 18px 40px rgba(58,148,255,.42), inset 0 1px 0 rgba(255,255,255,.4)}
}
@keyframes idBtnFly{
    0%,100%{transform:translate3d(-1px,1px,0) rotate(-10deg)}
    25%{transform:translate3d(2px,-2px,0) rotate(-4deg)}
    52%{transform:translate3d(5px,-1px,0) rotate(2deg)}
    78%{transform:translate3d(1px,2px,0) rotate(-7deg)}
}
@keyframes idBtnTrail{
    0%,100%{transform:scaleX(.7);opacity:.32}
    30%{transform:scaleX(1.08);opacity:.76}
    60%{transform:scaleX(.9);opacity:.54}
}
@keyframes idBtnSheen{
    0%,70%,100%{transform:translateX(-120%)}
    82%{transform:translateX(120%)}
}

.id-secured{
    align-self:center;
    margin-top:4px;
    padding:10px 14px;
    border-radius:999px;
    background:rgba(255,255,255,.032);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
    display:flex;align-items:center;justify-content:center;gap:6px;
    color:rgba(255,255,255,.38);
    font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
}
.id-secured .material-symbols-rounded{font-size:14px}

@media (max-width:420px){
    .id-card{border-radius:24px;padding:22px 16px 18px}
    .id-title{font-size:21px}
    .id-sub{font-size:13px}
    .id-icon-wrap{width:96px;height:96px}
    .id-icon{width:72px;height:72px;border-radius:24px}
    .id-icon .material-symbols-rounded{font-size:34px}
    .id-step-title{font-size:13.5px}
    .id-step-desc{font-size:12px}
    .id-btn{height:48px;font-size:13.5px}
}

/* ═══ CHECK TELEGRAM SCREEN ═══ */
body.frozen-mode #screenVerify{display:none}
body.frozen-mode #screenVerify.active{display:flex}

.ct-card{
    position:relative;
    z-index:2;
    margin-top:calc(var(--stop) + 18px);
    margin-bottom:18px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.018)),
        rgba(255,255,255,.018);
    border:none;
    border-radius:28px;
    padding:28px 20px 20px;
    box-shadow:
        0 24px 60px rgba(0,0,0,.5),
        inset 0 1px 0 rgba(255,255,255,.1);
    backdrop-filter:blur(36px) saturate(170%);
    -webkit-backdrop-filter:blur(36px) saturate(170%);
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:18px;
    overflow:hidden;
    animation:cardRise .55s cubic-bezier(.2,.7,.2,1);
}
.ct-card::before{
    content:'';
    position:absolute;
    left:14%;
    right:14%;
    top:-72px;
    height:180px;
    background:radial-gradient(circle, rgba(31,138,255,.18), rgba(31,138,255,0) 72%);
    pointer-events:none;
    filter:blur(6px);
}
.ct-card::after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:inherit;
    border:1px solid rgba(255,255,255,.035);
    pointer-events:none;
}

.ct-icon-wrap{
    position:relative;
    width:108px;height:108px;
    margin:0 auto 4px;
    display:flex;align-items:center;justify-content:center;
}
.ct-icon-backdrop{
    position:absolute;
    inset:10px;
    border-radius:30px;
    background:rgba(255,255,255,.03);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.08),
        0 12px 30px rgba(0,0,0,.24);
    backdrop-filter:blur(22px) saturate(150%);
    -webkit-backdrop-filter:blur(22px) saturate(150%);
}
.ct-icon{
    width:82px;height:82px;
    border-radius:28px;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    display:flex;align-items:center;justify-content:center;
    color:#fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.28),
        0 18px 36px rgba(21,114,216,.34);
    position:relative;z-index:2;
    animation:ctFloat 4.2s ease-in-out infinite;
}
.ct-icon .material-symbols-rounded{
    font-size:40px;
    font-variation-settings:'FILL' 1,'wght' 500;
}
.ct-icon-glow{
    position:absolute;
    inset:-8px;
    border-radius:34px;
    background:radial-gradient(circle, rgba(31,138,255,.26), rgba(31,138,255,0) 72%);
    filter:blur(14px);
    animation:breath 3s ease-in-out infinite;
}
.ct-icon-orbit{
    position:absolute;
    inset:2px;
    border-radius:34px;
    border:1px solid rgba(255,255,255,.08);
    mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    padding:8px;
    opacity:.7;
    animation:ctOrbit 7s linear infinite;
}
@keyframes ctOrbit{
    from{transform:rotate(0deg)}
    to{transform:rotate(360deg)}
}
@keyframes ctFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-5px)}
}

.ct-title{
    text-align:center;
    font-family:'Inter','SF Pro Display',-apple-system,sans-serif;
    font-size:25px;
    font-weight:700;
    letter-spacing:-.02em;
    color:#fff;
}
.ct-sub{
    text-align:center;
    font-family:'Inter','SF Pro Text',-apple-system,sans-serif;
    color:rgba(255,255,255,.64);
    font-size:14px;
    line-height:1.58;
    letter-spacing:-.005em;
    max-width:334px;
    margin:-6px auto 0;
}
.ct-sub b{color:#fff;font-weight:600}

.ct-msg{
    position:relative;
    background:linear-gradient(180deg, rgba(11,14,21,.88), rgba(17,19,26,.94));
    border:1px solid rgba(78,152,255,.2);
    border-radius:18px;
    padding:16px 14px 14px;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.06),
        0 12px 28px rgba(0,0,0,.28);
    backdrop-filter:blur(28px) saturate(160%);
    -webkit-backdrop-filter:blur(28px) saturate(160%);
    display:flex;flex-direction:column;gap:10px;
    animation:ctMsgIn .45s .15s both cubic-bezier(.2,.7,.2,1);
}
.ct-msg::before{
    content:'';
    position:absolute;
    left:14px;
    right:14px;
    top:0;
    height:1px;
    background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.16), rgba(255,255,255,0));
}
@keyframes ctMsgIn{
    from{opacity:0;transform:translateY(8px)}
    to{opacity:1;transform:none}
}
.ct-msg-head{
    display:flex;align-items:center;gap:8px;
    font-size:15px;font-weight:700;color:#fff;
    letter-spacing:-.005em;
}
.ct-msg-head-icon{
    width:28px;
    height:28px;
    border-radius:10px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    color:#fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.26),
        0 8px 16px rgba(21,114,216,.28);
}
.ct-msg-head-icon .material-symbols-rounded{
    font-size:18px;
    font-variation-settings:'FILL' 1,'wght' 500;
    transform:translateX(1px) rotate(-8deg);
}
.ct-msg-body{
    font-size:13.5px;
    line-height:1.58;
    color:rgba(255,255,255,.74);
    letter-spacing:-.005em;
}
.ct-msg-body b{color:#fff;font-weight:600}
.ct-msg-actions{display:flex;gap:10px;margin-top:6px}
.ct-msg-btn{
    flex:1;height:40px;
    display:flex;align-items:center;justify-content:center;gap:4px;
    border-radius:12px;
    font-size:13.5px;font-weight:600;letter-spacing:.005em;
    cursor:default;
    user-select:none;
}
.ct-msg-btn-decline{
    background:rgba(255,255,255,.05);
    color:rgba(255,255,255,.54);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.ct-msg-btn-accept{
    background:linear-gradient(180deg,#1f8aff,#1572d8);
    color:#fff;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.26),
        0 12px 24px rgba(21,114,216,.34);
    animation:ctAcceptPulse 2.6s ease-in-out infinite;
}
.ct-msg-btn-accept .material-symbols-rounded{font-size:16px;font-variation-settings:'wght' 700}
@keyframes ctAcceptPulse{
    0%,100%{box-shadow:inset 0 1px 0 rgba(255,255,255,.26), 0 12px 24px rgba(21,114,216,.3)}
    50%{box-shadow:inset 0 1px 0 rgba(255,255,255,.32), 0 16px 30px rgba(31,138,255,.42)}
}

.ct-waiting{
    align-self:center;
    margin-top:4px;
    padding:10px 14px;
    border-radius:999px;
    background:rgba(255,255,255,.032);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
    display:flex;align-items:center;justify-content:center;gap:8px;
    color:rgba(255,255,255,.52);
    font-size:13px;font-weight:500;
    position:relative;
    overflow:hidden;
}
.ct-waiting::before{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(110deg, rgba(255,255,255,0) 18%, rgba(255,255,255,.12) 48%, rgba(255,255,255,0) 76%);
    transform:translateX(-120%);
    animation:ctWaitingSheen 5s ease-in-out infinite;
}
.ct-waiting-icon{
    width:24px;
    height:24px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(31,138,255,.14);
    color:#84beff;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
    position:relative;
    animation:ctWaitingFloat 3.6s ease-in-out infinite;
}
.ct-waiting-icon::before{
    content:'';
    position:absolute;
    inset:-6px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(31,138,255,.28), rgba(31,138,255,0) 72%);
    filter:blur(8px);
    opacity:.55;
    animation:ctWaitingAura 3.6s ease-in-out infinite;
}
.ct-waiting-icon .material-symbols-rounded{
    font-size:15px;
    font-variation-settings:'FILL' 1,'wght' 500;
    animation:ctHourglass 2.8s cubic-bezier(.37,0,.2,1) infinite;
}
@keyframes ctHourglass{
    0%,16%{transform:rotate(0deg) scale(1)}
    32%{transform:rotate(0deg) scale(1.08)}
    50%{transform:rotate(180deg) scale(1.02)}
    66%{transform:rotate(180deg) scale(1)}
    82%{transform:rotate(360deg) scale(1.08)}
    100%{transform:rotate(360deg) scale(1)}
}
@keyframes ctWaitingFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-2px)}
}
@keyframes ctWaitingAura{
    0%,100%{opacity:.4;transform:scale(.92)}
    50%{opacity:.76;transform:scale(1.1)}
}
@keyframes ctWaitingSheen{
    0%,72%,100%{transform:translateX(-120%)}
    84%{transform:translateX(120%)}
}

@media (max-width:420px){
    .ct-card{border-radius:24px;padding:24px 16px 18px}
    .ct-title{font-size:21px}
    .ct-sub{font-size:13px}
    .ct-icon-wrap{width:96px;height:96px}
    .ct-icon{width:72px;height:72px;border-radius:24px}
    .ct-icon .material-symbols-rounded{font-size:34px}
    .ct-msg-body{font-size:13px}
}

/* ═══ GLASS CARD ═══ */
.card{
    background:var(--card);
    border:1px solid var(--b2);
    border-radius:var(--r);
    padding:20px 16px;
    display:flex;flex-direction:column;
}

/* ═══ INPUT ═══ */
.input-label{
    font-size:12px;font-weight:600;color:var(--t2);
    margin-bottom:8px;letter-spacing:.3px;text-transform:uppercase;
}
.input-wrap{
    display:flex;align-items:center;gap:8px;
    padding:12px 14px;
    background:rgba(255,255,255,.03);
    border:1px solid var(--b1);
    border-radius:var(--rs);
    transition:border-color .2s;
}
.input-wrap:focus-within{border-color:rgba(255,255,255,.15)}
.input-wrap.valid{border-color:rgba(34,197,94,.4)}
.input-wrap.invalid{border-color:rgba(239,68,68,.4)}
.input-wrap input{
    flex:1;background:none;border:none;outline:none;
    font-family:inherit;font-size:14px;font-weight:500;
    color:var(--t1);letter-spacing:.2px;
}
.input-wrap input::placeholder{color:rgba(255,255,255,.12)}
.input-icon{font-size:18px;color:var(--t3);flex-shrink:0;cursor:pointer}
.input-icon:active{opacity:.5}
.input-hint{
    font-size:11px;color:var(--t3);margin-top:6px;
    display:flex;align-items:center;gap:4px;
}

/* Copy button */
.copy-btn{
    background:none;border:none;padding:2px;cursor:pointer;
    color:var(--t3);transition:color .2s;font-size:16px;
}
.copy-btn:active{color:var(--green)}
.copy-btn.copied{color:var(--green)}

/* ═══ GIFT PREVIEW ═══ */
.gift-preview{
    display:flex;flex-direction:column;align-items:center;
    margin:16px 0 12px;opacity:0;max-height:0;
    transition:opacity .4s ease, max-height .4s ease;
    overflow:hidden;
}
.gift-preview.visible{opacity:1;max-height:260px}

/* Skeleton loader */
.gift-skeleton{
    width:120px;height:120px;border-radius:16px;
    background:linear-gradient(110deg,rgba(255,255,255,.02) 30%,rgba(255,255,255,.06) 50%,rgba(255,255,255,.02) 70%);
    background-size:200% 100%;
    animation:shimmer 1.5s ease-in-out infinite;
}
@keyframes shimmer{
    0%{background-position:200% 0}
    100%{background-position:-200% 0}
}

.gift-lottie{
    width:140px;height:140px;display:none;
}
.gift-lottie.loaded{display:block}
.gift-lottie.loaded + .gift-skeleton{display:none}

.gift-name{
    font-size:13px;font-weight:600;color:var(--t2);
    margin-top:8px;text-align:center;
    display:flex;align-items:center;gap:6px;
}

/* ═══ PROGRESS BAR ═══ */
.progress-wrap{
    width:100%;opacity:0;max-height:0;overflow:hidden;
    transition:opacity .3s, max-height .3s;
    margin-bottom:12px;
}
.progress-wrap.visible{opacity:1;max-height:50px}

.progress-bar{
    width:100%;height:3px;background:rgba(255,255,255,.06);
    border-radius:2px;overflow:hidden;position:relative;
}
.progress-fill{
    height:100%;width:0%;background:#fff;
    border-radius:2px;transition:width .05s linear;
    position:relative;
}
.progress-glow{
    position:absolute;right:-4px;top:-3px;
    width:10px;height:9px;border-radius:50%;
    background:#fff;filter:blur(4px);opacity:.7;
}
.progress-info{
    display:flex;justify-content:space-between;align-items:center;
    margin-top:6px;
}
.progress-label{font-size:11px;color:var(--t3);font-weight:500}
.progress-pct{font-size:11px;color:var(--t2);font-weight:700}

/* ═══ BUTTONS ═══ */
.btn{
    width:100%;padding:13px;border:none;border-radius:var(--rs);
    font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;
    transition:all .12s;display:flex;align-items:center;justify-content:center;gap:7px;
    margin-top:12px;
}
.btn:active{transform:scale(.97);opacity:.8}
.btn:disabled{opacity:.15;pointer-events:none}

.btn-white{background:#fff;color:#000}
.btn-ghost{
    background:rgba(255,255,255,.04);color:var(--t1);
    border:1px solid var(--b1);
}

.btn.loading{
    background:rgba(255,255,255,.06);color:var(--t2);
    pointer-events:none;
}

/* ═══ VERIFY SCREEN ═══ */
.verify-center{
    flex:1;display:flex;flex-direction:column;
    align-items:center;justify-content:center;
}

.verify-spinner-wrap{
    position:relative;width:64px;height:64px;margin-bottom:22px;
}

.spinner{
    width:44px;height:44px;
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    border:2px solid rgba(255,255,255,.06);
    border-top-color:#fff;border-radius:50%;
    animation:spin 1s linear infinite;
}
.spinner-ring{
    position:absolute;inset:0;border-radius:50%;
    border:1px solid rgba(255,255,255,.04);
    border-top-color:rgba(255,255,255,.12);
    animation:spin-ring 4s linear infinite reverse;
}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes spin-ring{to{transform:rotate(360deg)}}

.verify-title{font-size:19px;font-weight:700;text-align:center;margin-bottom:6px}
.verify-sub{
    font-size:12.5px;color:var(--t2);text-align:center;
    line-height:1.5;max-width:290px;
}
.verify-sub b{color:var(--t1);font-weight:600}

.verify-progress-bar{
    width:200px;height:3px;background:rgba(255,255,255,.06);
    border-radius:2px;overflow:hidden;margin-top:16px;
}
.verify-progress-fill{
    height:100%;width:0%;background:linear-gradient(90deg,rgba(255,255,255,.3),#fff);
    border-radius:2px;transition:width 1s linear;
}

.verify-hint{
    font-size:11px;color:var(--t3);margin-top:12px;
    animation:verifyPulse 2s ease-in-out infinite;
}
@keyframes verifyPulse{
    0%,100%{opacity:.4}
    50%{opacity:1}
}

.timer{
    display:flex;align-items:center;gap:6px;padding:6px 14px;
    background:rgba(255,255,255,.03);border-radius:20px;
    font-size:14px;font-weight:600;color:var(--t2);margin-top:12px;
}

/* ═══ PORTALS INFO SCREEN ═══ */
.portals-info-card{
    background:var(--card);border:1px solid var(--b2);
    border-radius:var(--r);padding:28px 18px 22px;
    display:flex;flex-direction:column;align-items:center;
    flex:1;animation:piSlideUp .4s cubic-bezier(.16,1,.3,1);
}
@keyframes piSlideUp{
    from{opacity:0;transform:translateY(20px)}
    to{opacity:1;transform:none}
}

.pi-icon-wrap{
    position:relative;width:64px;height:64px;margin-bottom:18px;
}
.pi-icon{
    width:56px;height:56px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);z-index:2;
    animation:piIconFloat 3s ease-in-out infinite;
}
.pi-icon svg{color:var(--t1)}
@keyframes piIconFloat{
    0%,100%{transform:translate(-50%,-50%) translateY(0)}
    50%{transform:translate(-50%,-50%) translateY(-3px)}
}
.pi-icon-ring{
    position:absolute;inset:-4px;border-radius:50%;
    border:1px solid rgba(255,255,255,.06);
    animation:piRingPulse 2.5s ease-in-out infinite;
}
.pi-icon-ring-2{
    inset:-12px;border-color:rgba(255,255,255,.03);
    animation-delay:.5s;
}
@keyframes piRingPulse{
    0%,100%{transform:scale(1);opacity:.5}
    50%{transform:scale(1.08);opacity:.15}
}

.pi-title{
    font-size:20px;font-weight:800;text-align:center;
    margin-bottom:8px;letter-spacing:-.3px;
}
.pi-sub{
    font-size:12.5px;color:var(--t2);text-align:center;
    line-height:1.55;max-width:300px;margin-bottom:20px;
}
.pi-sub b{color:var(--t1);font-weight:600}

.pi-feature-list{
    width:100%;display:flex;flex-direction:column;gap:10px;
    margin-bottom:18px;
}
.pi-feature{
    display:flex;align-items:flex-start;gap:12px;
    padding:12px 14px;
    background:rgba(255,255,255,.02);
    border:1px solid rgba(255,255,255,.04);
    border-radius:var(--rs);
    transition:border-color .3s, background .3s;
    animation:piFeatureIn .5s cubic-bezier(.16,1,.3,1) both;
}
.pi-feature:nth-child(1){animation-delay:.1s}
.pi-feature:nth-child(2){animation-delay:.2s}
.pi-feature:nth-child(3){animation-delay:.3s}
@keyframes piFeatureIn{
    from{opacity:0;transform:translateX(-10px)}
    to{opacity:1;transform:none}
}

.pi-feature-icon{
    width:32px;height:32px;border-radius:8px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.06);
}
.pi-feature-icon svg{color:var(--t1)}

.pi-feature-text{
    display:flex;flex-direction:column;gap:2px;min-width:0;
}
.pi-feature-title{
    font-size:13px;font-weight:700;color:var(--t1);
}
.pi-feature-desc{
    font-size:11px;color:var(--t2);line-height:1.4;
}

.pi-disclaimer{
    display:flex;align-items:flex-start;gap:8px;
    padding:10px 12px;width:100%;
    background:rgba(255,255,255,.015);
    border:1px solid rgba(255,255,255,.04);
    border-radius:var(--rs);
    font-size:10.5px;color:var(--t3);line-height:1.4;
    margin-bottom:16px;
}
.pi-disclaimer svg{flex-shrink:0;margin-top:1px;color:var(--t3)}

/* Glow button */
.btn-glow{
    position:relative;overflow:hidden;
}
.btn-glow::before{
    content:'';position:absolute;inset:-1px;
    background:linear-gradient(135deg,rgba(255,255,255,.2),transparent 50%,rgba(255,255,255,.1));
    opacity:0;transition:opacity .3s;z-index:0;border-radius:inherit;
}
.btn-glow:active::before{opacity:1}
.btn-glow>*{position:relative;z-index:1}
.btn-glow::after{
    content:'';position:absolute;top:50%;left:50%;
    width:200%;height:200%;
    background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 60%);
    transform:translate(-50%,-50%) scale(0);
    transition:transform .5s;border-radius:50%;
}
.btn-glow:active::after{transform:translate(-50%,-50%) scale(1)}

/* ═══ RESULT SCREEN ═══ */
.result-card{
    background:var(--card);border:1px solid var(--b2);
    border-radius:var(--r);padding:24px 18px;
    display:flex;flex-direction:column;align-items:center;
    flex:1;
}

.res-icon{
    width:56px;height:56px;border-radius:50%;display:flex;
    align-items:center;justify-content:center;margin-bottom:14px;
}
.res-icon.warn{
    background:rgba(239,68,68,.08);
    border:1px solid rgba(239,68,68,.2);
}
.res-icon.warn svg{color:var(--red)}
.res-icon.ok{
    background:rgba(34,197,94,.08);
    border:1px solid rgba(34,197,94,.2);
}

.res-title{font-size:18px;font-weight:700;text-align:center;margin-bottom:6px}
.res-body{
    font-size:12.5px;color:var(--t2);text-align:center;
    line-height:1.5;max-width:300px;margin-bottom:14px;
}
.res-body b{color:var(--t1);font-weight:600}

.res-warning{
    display:flex;align-items:flex-start;gap:8px;
    padding:10px 12px;width:100%;
    background:rgba(239,68,68,.04);
    border:1px solid rgba(239,68,68,.12);
    border-radius:var(--rs);
    font-size:11px;color:var(--red);line-height:1.4;
    margin-top:12px;
}
.res-warning svg{flex-shrink:0;margin-top:1px;width:14px;height:14px}

.res-notice{
    display:flex;align-items:flex-start;gap:8px;
    padding:10px 12px;width:100%;
    background:rgba(255,255,255,.02);
    border:1px solid var(--b2);
    border-radius:var(--rs);
    font-size:11px;color:var(--t2);line-height:1.4;
    margin-top:8px;
}
.res-notice b{color:var(--t1);font-weight:600}

/* ═══ ERROR SCREEN ═══ */
.err-icon{
    width:56px;height:56px;border-radius:50%;display:flex;
    align-items:center;justify-content:center;margin-bottom:14px;
    background:rgba(255,255,255,.03);border:1px solid var(--b2);
}

/* ═══ SENT SCREEN ═══ */
.sent-card{
    background:var(--card);border:1px solid var(--b2);
    border-radius:var(--r);padding:24px 18px;
    display:flex;flex-direction:column;align-items:center;
    flex:1;justify-content:center;
}

/* ═══ TOAST ═══ */
.toast{
    position:fixed;top:calc(var(--stop) + 12px);left:50%;
    transform:translateX(-50%) translateY(-20px);
    background:rgba(20,20,20,.95);color:#fff;
    padding:10px 20px;border-radius:10px;
    font-size:13px;font-weight:500;z-index:999;
    border:1px solid var(--b1);
    opacity:0;pointer-events:none;
    transition:all .25s ease;
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    max-width:90vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}

/* ═══ LOADING SCREEN ═══ */
.loading-screen{
    position:fixed;inset:0;z-index:9999;
    background:#000;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:16px;
    transition:opacity .4s ease;
}
.loading-screen.hidden{opacity:0;pointer-events:none}
.loading-logo-wrap{position:relative;width:64px;height:64px}
.loading-logo{
    width:64px;height:64px;border-radius:16px;
    position:relative;z-index:2;
}
.loading-pulse{
    position:absolute;inset:-8px;border-radius:22px;z-index:1;
    border:2px solid rgba(255,255,255,.08);
    animation:loadPulse 1.2s ease-in-out infinite;
}
@keyframes loadPulse{
    0%,100%{transform:scale(1);opacity:.3}
    50%{transform:scale(1.1);opacity:.08}
}
.loading-text{
    font-size:14px;font-weight:700;color:rgba(255,255,255,.25);
    letter-spacing:.5px;
}

/* ═══ TOPBAR LOGO ═══ */
.topbar-logo{
    width:24px;height:24px;border-radius:6px;
    object-fit:cover;
}

/* ═══ FOOTER ═══ */
.footer{
    display:flex;flex-direction:column;align-items:center;
    justify-content:center;padding:24px 16px 12px;
    margin-top:auto;gap:3px;
}
.footer-line{
    font-size:11px;font-weight:600;color:rgba(255,255,255,.15);
    text-align:center;letter-spacing:.3px;
}
.footer-sub{
    font-size:9px;font-weight:700;color:rgba(255,255,255,.08);
    text-transform:uppercase;letter-spacing:1.5px;text-align:center;
}

/* ═══ RESPONSIVE ═══ */
@media(max-height:640px){
    .home-banner{margin-bottom:10px}
    .card{padding:14px 12px}
    .gift-preview.visible{max-height:180px}
    .gift-lottie{width:100px;height:100px}
}
