@font-face{font-family:IranSans;src:url(/fonts/IRANSansWeb.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Dana;src:url(/fonts/FA/Dana/Variable/DanaVF.ttf) format("truetype");font-weight:100 900;font-style:normal;font-display:swap}:root{--bg: #f4f5fb;--bg-soft: #ecedf7;--bg-deep: #e6e8f4;--surface: #ffffff;--surface-2: #fafbff;--surface-3: #f3f4fb;--surface-glass: rgba(255, 255, 255, .78);--text: #0b1023;--text-soft: #2d3450;--text-muted: #6b7390;--text-faint: #9aa1bd;--border: rgba(11, 16, 35, .08);--border-strong: rgba(11, 16, 35, .14);--hairline: rgba(11, 16, 35, .05);--brand-50: #eef0ff;--brand-100: #dde0ff;--brand-200: #bcc1ff;--brand-400: #6f76ff;--brand: #4f46e5;--brand-600: #4338ca;--brand-700: #3730a3;--brand-soft: rgba(79, 70, 229, .1);--brand-grad: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #ec4899 100%);--brand-grad-soft: linear-gradient(135deg, rgba(99,102,241,.1), rgba(236,72,153,.06));--wallet-grad: linear-gradient(140deg, #1e1b4b 0%, #4338ca 45%, #7c3aed 100%);--success: #10b981;--success-soft: rgba(16, 185, 129, .12);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .14);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .12);--info: #0ea5e9;--info-soft: rgba(14, 165, 233, .14);--shadow-xs: 0 1px 2px rgba(11, 16, 35, .04);--shadow-sm: 0 4px 12px rgba(11, 16, 35, .06);--shadow-md: 0 12px 28px -8px rgba(11, 16, 35, .12);--shadow-lg: 0 22px 50px -16px rgba(11, 16, 35, .22);--shadow-brand: 0 18px 40px -14px rgba(79, 70, 229, .45);--radius-xs: 8px;--radius-sm: 12px;--radius-md: 18px;--radius-lg: 24px;--radius-xl: 32px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--app-max: 480px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--nav-height: 76px}:root[data-theme=dark]{--bg: #06070d;--bg-soft: #0c0f1d;--bg-deep: #0a0c17;--surface: #11142a;--surface-2: #161a36;--surface-3: #1a1f44;--surface-glass: rgba(17, 20, 42, .74);--text: #ecedf7;--text-soft: #c9cbe3;--text-muted: #8e92b3;--text-faint: #5b6088;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .14);--hairline: rgba(255, 255, 255, .05);--brand-50: rgba(129, 140, 248, .08);--brand-100: rgba(129, 140, 248, .18);--brand-200: rgba(129, 140, 248, .28);--brand-400: #a5b4fc;--brand: #818cf8;--brand-600: #6366f1;--brand-700: #4f46e5;--brand-soft: rgba(129, 140, 248, .18);--brand-grad: linear-gradient(135deg, #818cf8 0%, #a78bfa 50%, #f472b6 100%);--brand-grad-soft: linear-gradient(135deg, rgba(129,140,248,.12), rgba(244,114,182,.08));--wallet-grad: linear-gradient(140deg, #1e1b4b 0%, #4f46e5 45%, #c026d3 100%);--success: #34d399;--success-soft: rgba(52, 211, 153, .16);--warning: #fbbf24;--warning-soft: rgba(251, 191, 36, .18);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .18);--info: #38bdf8;--info-soft: rgba(56, 189, 248, .18);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .4);--shadow-sm: 0 6px 18px rgba(0, 0, 0, .4);--shadow-md: 0 14px 30px -10px rgba(0, 0, 0, .6);--shadow-lg: 0 26px 60px -18px rgba(0, 0, 0, .7);--shadow-brand: 0 18px 40px -10px rgba(129, 140, 248, .55)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:Dana,IranSans,IRANSans,Vazirmatn,Tahoma,sans-serif;background:radial-gradient(1100px 600px at 110% -10%,var(--brand-soft),transparent 55%),radial-gradient(900px 500px at -20% 110%,color-mix(in srgb,var(--brand) 18%,transparent),transparent 55%),var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:15px;line-height:1.55;letter-spacing:-.005em}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;letter-spacing:-.02em;font-weight:800;color:var(--text)}h2{font-size:1.18rem}h3{font-size:1.02rem;font-weight:750}h4{font-size:.92rem;font-weight:700}p{margin:0;color:var(--text-soft)}small{color:var(--text-muted)}button{font-family:inherit}.app-shell{position:relative;min-height:100dvh;max-width:var(--app-max);margin:0 auto;display:flex;flex-direction:column;padding:calc(var(--safe-top) + var(--space-3)) var(--space-4) calc(var(--nav-height) + var(--safe-bottom) + var(--space-4));gap:var(--space-3)}.glass{backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);background:var(--surface-glass);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.topbar{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.topbar-user{display:flex;align-items:center;gap:var(--space-3);min-width:0}.topbar-avatar{width:42px;height:42px;border-radius:14px;background:var(--brand-grad);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.95rem;box-shadow:var(--shadow-brand);flex-shrink:0}.topbar-greeting{display:flex;flex-direction:column;gap:2px;min-width:0}.topbar-greeting small{font-size:.72rem;color:var(--text-muted)}.topbar-greeting strong{font-size:.95rem;font-weight:750;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.topbar-actions{display:flex;align-items:center;gap:var(--space-2)}.icon-btn{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);display:grid;place-items:center;cursor:pointer;position:relative;transition:transform .12s ease,background .12s ease,color .12s ease}.icon-btn:hover{background:var(--brand-soft);color:var(--brand)}.icon-btn:active{transform:scale(.96)}.icon-btn .dot-badge{position:absolute;top:6px;inset-inline-end:6px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:700;font-style:normal;line-height:16px;text-align:center}.banner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:.82rem;font-weight:600;line-height:1.4}.banner svg{flex-shrink:0}.banner.is-danger{background:var(--danger-soft);color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent)}.banner.is-info{background:var(--info-soft);color:var(--info);border:1px solid color-mix(in srgb,var(--info) 30%,transparent)}.banner.is-brand{background:var(--brand-soft);color:var(--brand);border:1px solid color-mix(in srgb,var(--brand) 30%,transparent)}.banner-actions{margin-inline-start:auto;display:flex;gap:var(--space-2)}.sync-pill-wrap{display:flex;flex-direction:column;align-items:stretch}.sync-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:8px 14px;border-radius:var(--radius-pill);background:var(--warning-soft);color:color-mix(in srgb,var(--warning) 70%,var(--text));border:1px solid color-mix(in srgb,var(--warning) 30%,transparent);font-size:.78rem;font-weight:650;cursor:pointer;list-style:none;width:fit-content;align-self:center}.sync-pill::-webkit-details-marker{display:none}.sync-pill .pulse{width:8px;height:8px;border-radius:50%;background:var(--warning);animation:pulse 1.4s ease-in-out infinite;flex-shrink:0}.sync-pill.is-syncing{background:var(--info-soft);color:color-mix(in srgb,var(--info) 70%,var(--text));border-color:color-mix(in srgb,var(--info) 30%,transparent)}.sync-pill.is-syncing .pulse{background:var(--info)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.8)}}.sync-panel{margin-top:var(--space-2);padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-3)}.sync-overview{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.sync-overview small{font-size:.74rem;color:var(--text-muted)}.sync-type-summary{display:flex;flex-wrap:wrap;gap:var(--space-2)}.sync-status-item{border:1px solid var(--border);background:var(--surface-2);border-radius:var(--radius-sm);padding:var(--space-3);display:grid;gap:4px}.sync-status-item.is-failed{background:var(--danger-soft);border-color:color-mix(in srgb,var(--danger) 30%,transparent)}.sync-status-item small{font-size:.74rem;color:var(--text-muted)}.sync-files{display:grid;gap:4px;margin-top:4px}.sync-progress-wrap{display:grid;gap:4px;margin-top:6px}.sync-progress-bar{width:100%;height:6px;border-radius:999px;overflow:hidden;background:var(--surface-3)}.sync-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--brand-400),var(--brand));transition:width .2s ease}.sync-summary{font-size:.74rem;color:var(--text-muted)}.sync-logs{border-top:1px dashed var(--border);margin-top:var(--space-2);padding-top:var(--space-3);display:grid;gap:var(--space-2)}.sync-log-item{border:1px solid var(--border);border-radius:var(--radius-xs);padding:6px 8px;display:grid;gap:2px}.content-area{display:flex;flex-direction:column;gap:var(--space-3);flex:1;min-height:0}.page{display:flex;flex-direction:column;gap:var(--space-4);padding-bottom:var(--space-2)}.section-head{padding:var(--space-1) var(--space-1) 0;display:flex;flex-direction:column;gap:4px}.section-head h2{font-size:1.22rem;font-weight:800}.section-head p{color:var(--text-muted);font-size:.85rem}.section-head-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-1) var(--space-1) 0}.section-link{font-size:.78rem;color:var(--brand);font-weight:650}.overline{margin:0 0 4px;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.panel,.feature-card,.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.panel{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.panel h3{margin:0}.panel p{color:var(--text-muted)}.panel-row{border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-3);background:var(--surface-2)}.panel-row small{display:block;color:var(--text-muted);margin-top:4px;font-size:.78rem}.panel-button{width:100%;text-align:right;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease;color:var(--text)}.panel-button:hover,.panel-button:focus-visible{transform:translateY(-2px);border-color:var(--brand-200);box-shadow:var(--shadow-md)}.panel-button h3,.panel-button p{pointer-events:none}.panel-button p{font-size:.82rem;color:var(--text-muted)}.row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.stack{display:flex;flex-direction:column;gap:var(--space-3)}.grid-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.badge{display:inline-flex;align-items:center;gap:4px;background:var(--brand-soft);color:var(--brand);border:1px solid transparent;border-radius:var(--radius-pill);padding:4px 10px;font-size:.72rem;font-weight:650}.badge.is-success{background:var(--success-soft);color:var(--success)}.badge.is-danger{background:var(--danger-soft);color:var(--danger)}.badge.is-warning{background:var(--warning-soft);color:color-mix(in srgb,var(--warning) 80%,var(--text))}.badge.is-info{background:var(--info-soft);color:var(--info)}.badge.is-muted{background:var(--surface-3);color:var(--text-muted)}.chip{border:1px solid var(--border);background:var(--surface-2);border-radius:var(--radius-pill);padding:6px 12px;font-size:.78rem;color:var(--text-muted);cursor:pointer;font-weight:600;transition:all .14s ease}.chip.is-active{border-color:transparent;background:var(--brand);color:#fff;box-shadow:var(--shadow-brand)}.chips-row{display:flex;flex-wrap:wrap;gap:6px}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:14px;padding:10px 16px;cursor:pointer;font-weight:700;font-size:.86rem;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--brand-grad);color:#fff;border-color:transparent;box-shadow:var(--shadow-brand)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent}.btn-ghost:hover{color:var(--brand);background:var(--brand-soft)}.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 30%,transparent)}.btn-success{background:var(--success-soft);color:var(--success);border-color:color-mix(in srgb,var(--success) 30%,transparent)}.btn-block{width:100%}.btn-xs{padding:5px 10px;font-size:.74rem;border-radius:10px;font-weight:650}.btn-row{display:flex;gap:var(--space-2);flex-wrap:wrap}.wallet-hero{background:var(--wallet-grad);border-radius:var(--radius-lg);padding:var(--space-5);color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--space-4);isolation:isolate}.wallet-hero:before,.wallet-hero:after{content:"";position:absolute;border-radius:50%;z-index:-1;filter:blur(8px)}.wallet-hero:before{width:220px;height:220px;background:radial-gradient(circle,rgba(236,72,153,.45),transparent 65%);top:-90px;inset-inline-end:-60px}.wallet-hero:after{width:180px;height:180px;background:radial-gradient(circle,rgba(99,102,241,.5),transparent 65%);bottom:-80px;inset-inline-start:-50px}.wallet-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.wallet-hero-top small{color:#ffffffb3;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.wallet-hero-balance{display:flex;align-items:baseline;gap:8px;margin-top:4px}.wallet-hero-balance .amount{font-size:2.1rem;font-weight:800;letter-spacing:-.03em;line-height:1}.wallet-hero-balance .currency{font-size:.95rem;color:#ffffffc7;font-weight:700}.wallet-hero-meta{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:.78rem;color:#ffffffc7}.wallet-hero-meta strong{color:#fff;font-weight:750}.wallet-hero-card-chip{width:44px;height:32px;border-radius:8px;background:linear-gradient(135deg,#ffffff59,#ffffff1f);border:1px solid rgba(255,255,255,.25)}.wallet-hero-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2)}.wallet-action-btn{border:1px solid rgba(255,255,255,.18);background:#ffffff1a;color:#fff;border-radius:14px;padding:10px 8px;font-size:.78rem;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .14s ease,transform .12s ease}.wallet-action-btn:hover{background:#ffffff2e}.wallet-action-btn:active{transform:scale(.97)}.wallet-action-btn .icon-circle{width:36px;height:36px;border-radius:12px;background:#ffffff2e;display:grid;place-items:center}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-2)}.quick-action{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;cursor:pointer;position:relative;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease;box-shadow:var(--shadow-xs);color:var(--text)}.quick-action:hover{transform:translateY(-2px);border-color:var(--brand-200);box-shadow:var(--shadow-md)}.quick-action .qa-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:1rem;box-shadow:var(--shadow-sm)}.quick-action span{font-size:.74rem;font-weight:650;color:var(--text-soft);line-height:1.2}.quick-action .qa-badge{position:absolute;top:6px;inset-inline-end:6px;min-width:18px;padding:0 5px;height:18px;border-radius:999px;background:var(--danger);color:#fff;font-size:.64rem;font-weight:700;display:grid;place-items:center;font-style:normal}.qa-icon.c-violet{background:linear-gradient(135deg,#8b5cf6,#6366f1)}.qa-icon.c-pink{background:linear-gradient(135deg,#ec4899,#db2777)}.qa-icon.c-amber{background:linear-gradient(135deg,#f59e0b,#ea580c)}.qa-icon.c-emerald{background:linear-gradient(135deg,#10b981,#059669)}.qa-icon.c-sky{background:linear-gradient(135deg,#38bdf8,#0284c7)}.qa-icon.c-rose{background:linear-gradient(135deg,#fb7185,#e11d48)}.qa-icon.c-lime{background:linear-gradient(135deg,#84cc16,#65a30d)}.qa-icon.c-indigo{background:linear-gradient(135deg,#6366f1,#4338ca)}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.stat-card{padding:var(--space-4);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.stat-card .stat-icon{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;color:var(--brand);background:var(--brand-soft);margin-bottom:4px}.stat-card .stat-icon.is-success{color:var(--success);background:var(--success-soft)}.stat-card .stat-icon.is-warning{color:color-mix(in srgb,var(--warning) 80%,var(--text));background:var(--warning-soft)}.stat-card .stat-icon.is-danger{color:var(--danger);background:var(--danger-soft)}.stat-card .stat-icon.is-info{color:var(--info);background:var(--info-soft)}.stat-card span{display:block;color:var(--text-muted);font-size:.76rem;font-weight:600}.stat-card strong{font-size:1.1rem;font-weight:800;color:var(--text);letter-spacing:-.01em}.stat-card .stat-trend{font-size:.72rem;font-weight:650;display:inline-flex;align-items:center;gap:2px}.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}.h-scroll{display:flex;gap:var(--space-3);overflow-x:auto;padding:4px 2px var(--space-2);margin:0 calc(var(--space-4) * -1);padding-inline-start:var(--space-4);padding-inline-end:var(--space-4);scroll-snap-type:x mandatory;scrollbar-width:none}.h-scroll::-webkit-scrollbar{display:none}.featured-card{flex:0 0 78%;scroll-snap-align:start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);text-decoration:none;color:var(--text);transition:transform .16s ease,box-shadow .16s ease}.featured-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.featured-card-banner{height:96px;background:var(--brand-grad);position:relative;display:flex;align-items:flex-end;padding:var(--space-3)}.featured-card-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(180px 180px at 90% -20%,rgba(255,255,255,.32),transparent 60%),radial-gradient(220px 180px at 10% 110%,rgba(0,0,0,.18),transparent 60%)}.featured-card-banner .badge{background:#ffffff38;color:#fff;border-color:#ffffff2e;position:relative;z-index:1}.featured-card-body{padding:var(--space-3) var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.featured-card-body h3{font-size:1rem}.featured-card-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding-top:var(--space-2);border-top:1px dashed var(--border)}.featured-card-meta small{font-size:.74rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:4px}.featured-card-meta .price{color:var(--brand);font-weight:800;font-size:.92rem}.activity-list{display:flex;flex-direction:column;gap:var(--space-2)}.activity-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.activity-item .a-icon{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand);flex-shrink:0}.activity-item .a-icon.is-success{background:var(--success-soft);color:var(--success)}.activity-item .a-icon.is-danger{background:var(--danger-soft);color:var(--danger)}.activity-item .a-icon.is-warning{background:var(--warning-soft);color:color-mix(in srgb,var(--warning) 80%,var(--text))}.activity-item .a-icon.is-info{background:var(--info-soft);color:var(--info)}.activity-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.activity-item-body strong{font-size:.88rem;font-weight:700;color:var(--text)}.activity-item-body small{font-size:.74rem;color:var(--text-muted)}.activity-item-amount{font-weight:800;font-size:.92rem;color:var(--text);white-space:nowrap}.activity-item-amount.is-positive{color:var(--success)}.activity-item-amount.is-negative{color:var(--danger)}.wallet-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.shop-grid{display:flex;flex-direction:column;gap:var(--space-3)}.shop-page{overflow-x:hidden}.shop-orbit-wrap{margin-top:var(--space-1);margin-inline:calc(var(--space-3) * -1);padding-bottom:0;overflow:hidden}.shop-orbit-hint{position:absolute;top:6px;left:50%;transform:translate(-50%);z-index:5;text-align:center;font-size:.68rem;color:var(--text-muted);letter-spacing:.02em;pointer-events:none;white-space:nowrap;padding:2px 10px;border-radius:999px;background:color-mix(in srgb,var(--surface) 88%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.shop-orbit-scene{position:relative;height:min(52vh,560px);min-height:300px;perspective:900px;perspective-origin:50% 42%;touch-action:none;cursor:grab;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;overflow:hidden}@media(max-width:639px){.shop-orbit-scene{height:clamp(300px,46vh,380px);min-height:0;perspective:720px;perspective-origin:50% 44%}.shop-orbit-item{top:50%;width:min(88vw,280px)}.shop-orbit-floor{bottom:4%;height:72px}.shop-orbit-controls{margin-top:var(--space-1)}}.shop-orbit-scene.is-dragging{cursor:grabbing}.shop-orbit-scene.is-snapping .shop-orbit-item{transition:transform .42s cubic-bezier(.22,1,.36,1),opacity .32s ease}.shop-orbit-floor{position:absolute;left:50%;bottom:8%;width:min(92%,420px);height:120px;transform:translate(-50%) rotateX(78deg);border-radius:50%;background:radial-gradient(ellipse at center,rgba(139,92,246,.28) 0%,rgba(139,92,246,.06) 45%,transparent 72%);filter:blur(2px);pointer-events:none}.shop-orbit-stage{position:absolute;top:0;right:0;bottom:0;left:0;transform-style:preserve-3d}.shop-orbit-item{position:absolute;left:50%;top:48%;width:min(82vw,300px);transform-style:preserve-3d;transition:transform .28s cubic-bezier(.22,1,.36,1),opacity .22s ease;will-change:transform,opacity;backface-visibility:hidden;touch-action:none}.shop-orbit-item.is-active{pointer-events:auto}.shop-orbit-item:not(.is-active){pointer-events:auto}.shop-orbit-item.is-active .shop-card-orbit{box-shadow:0 24px 48px #0f172a38,0 0 0 1px #8b5cf62e}.shop-orbit-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-1);padding-inline:var(--space-3)}.shop-orbit-nav{width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);display:grid;place-items:center;box-shadow:var(--shadow-sm);cursor:pointer;transition:background .14s ease,transform .14s ease}.shop-orbit-nav:active{transform:scale(.94)}.shop-orbit-dots{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;max-width:220px}.shop-orbit-dot{width:8px;height:8px;border-radius:999px;border:none;padding:0;background:var(--border);cursor:pointer;transition:width .18s ease,background .18s ease}.shop-orbit-dot.is-active{width:22px;background:var(--brand)}.shop-card-orbit{width:100%;position:relative}.shop-card-orbit.is-compact .shop-card-body{padding:var(--space-3)}.shop-card-orbit.is-compact .shop-metrics{gap:6px}.shop-card-orbit.is-compact .shop-metric{padding:8px}.shop-card-badge{position:absolute;top:8px;inset-inline-end:8;font-size:.7rem;padding:2px 8px;border-radius:6px;z-index:2;color:#fff}.shop-card-badge.is-danger{background:var(--danger, #e74c3c)}.shop-card-badge.is-brand{background:var(--brand, #8b5cf6)}.shop-owned-preorder{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.shop-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .16s ease,box-shadow .16s ease}.shop-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.shop-card-banner{background:var(--brand-grad);padding:var(--space-4);position:relative;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);overflow:hidden}.shop-card-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(220px 220px at 100% 0%,rgba(255,255,255,.26),transparent 60%),radial-gradient(160px 200px at 0% 100%,rgba(0,0,0,.12),transparent 60%)}.shop-card-banner>*{position:relative;z-index:1}.shop-card-banner h3{color:#fff;font-size:1.05rem;font-weight:800}.shop-card-banner small{color:#ffffffc7;font-size:.74rem;font-weight:600}.shop-card-banner .pkg-icon{width:50px;height:50px;border-radius:14px;background:#ffffff2e;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;color:#fff}.shop-card-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.shop-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2)}.shop-metric{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;display:flex;flex-direction:column;align-items:flex-start;gap:4px}.shop-metric small{display:block;color:var(--text-muted);font-size:.7rem;font-weight:600}.shop-metric strong{font-size:.9rem;font-weight:800;color:var(--text)}.shop-metric .m-icon{width:26px;height:26px;border-radius:8px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;margin-bottom:2px}.shop-card-bottom{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-top:var(--space-2);border-top:1px dashed var(--border)}.shop-price-wrap{display:flex;flex-direction:column;gap:2px}.price-display,.price-display-inline{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.price-display-inline{align-items:flex-start}.price-display-primary{font-weight:800;color:var(--brand)}.price-display-secondary{font-size:.7rem;color:var(--text-muted);font-weight:500}.price-display-hint{font-size:.68rem;color:var(--text-muted)}.purchase-summary-card .row-price{align-items:flex-end}.purchase-summary-card .row-price .price-display-primary{font-size:.88rem}.purchase-course-price .price-display-primary{font-size:.78rem}.purchase-course-price .price-display-secondary{font-size:.62rem}.shop-price-wrap small{font-size:.7rem;color:var(--text-muted)}.shop-price{font-size:1.1rem;font-weight:800;color:var(--brand);letter-spacing:-.02em}.bottom-nav{position:fixed;bottom:calc(var(--safe-bottom) + 12px);left:50%;transform:translate(-50%);width:min(var(--app-max),calc(100% - 24px));z-index:50;border-radius:var(--radius-xl);padding:8px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;background:var(--surface-glass);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid var(--border);box-shadow:var(--shadow-lg)}.bottom-nav a{position:relative;padding:10px 4px;border-radius:18px;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-muted);font-size:.66rem;font-weight:650;transition:color .16s ease,background .16s ease}.bottom-nav a svg{transition:transform .16s ease}.bottom-nav a.active{background:var(--brand-grad);color:#fff;box-shadow:var(--shadow-brand)}.bottom-nav a.active svg{transform:scale(1.08)}.bottom-nav a span{white-space:nowrap;letter-spacing:-.01em}.nav-badge{position:absolute;top:4px;inset-inline-end:8px;min-width:16px;height:16px;border-radius:999px;padding:0 4px;background:var(--danger);color:#fff;font-style:normal;font-size:.62rem;font-weight:700;line-height:16px;text-align:center}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0508188c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:80;opacity:0;pointer-events:none;transition:opacity .22s ease}.drawer-overlay.is-open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;height:100dvh;width:min(320px,88vw);background:var(--surface);border-left:1px solid var(--border);box-shadow:-16px 0 50px -8px #05081866;z-index:90;transform:translate3d(110%,0,0);transition:transform .28s cubic-bezier(.32,.72,.2,1);display:flex;flex-direction:column;padding-top:var(--safe-top);will-change:transform}.drawer.is-open{transform:translateZ(0)}[dir=ltr] .drawer{right:auto;left:0;border-left:0;border-right:1px solid var(--border);box-shadow:16px 0 50px -8px #05081866;transform:translate3d(-110%,0,0)}[dir=ltr] .drawer.is-open{transform:translateZ(0)}.drawer-header{padding:var(--space-5) var(--space-4) var(--space-4);display:flex;align-items:center;gap:var(--space-3);background:var(--brand-grad);color:#fff;position:relative;overflow:hidden}.drawer-header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(220px 200px at 100% 0%,rgba(255,255,255,.28),transparent 60%),radial-gradient(200px 180px at 0% 100%,rgba(0,0,0,.18),transparent 60%)}.drawer-header>*{position:relative;z-index:1}.drawer-avatar{width:56px;height:56px;border-radius:18px;background:#fff3;border:1px solid rgba(255,255,255,.28);display:grid;place-items:center;font-weight:800;font-size:1.2rem;color:#fff;flex-shrink:0}.drawer-user{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.drawer-user strong{color:#fff;font-size:1rem;font-weight:750;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-user small{color:#ffffffc7;font-size:.78rem}.drawer-close{width:36px;height:36px;border-radius:12px;border:1px solid rgba(255,255,255,.22);background:#ffffff24;color:#fff;display:grid;place-items:center;cursor:pointer;flex-shrink:0}.drawer-body{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.drawer-section-label{padding:var(--space-3) var(--space-3) 4px;font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.drawer-link{display:flex;align-items:center;gap:var(--space-3);padding:12px var(--space-3);border-radius:14px;color:var(--text-soft);font-weight:650;font-size:.9rem;background:transparent;border:0;cursor:pointer;text-align:start;width:100%;position:relative;transition:background .14s ease,color .14s ease}.drawer-link:hover{background:var(--brand-soft);color:var(--brand)}.drawer-link.active{background:var(--brand-soft);color:var(--brand);font-weight:750}.drawer-link .d-icon,.drawer-link .qa-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;color:#fff;box-shadow:var(--shadow-xs)}.drawer-link .d-icon:not(.qa-icon){background:var(--surface-3);color:var(--text-soft);box-shadow:none}.drawer-link.active .d-icon:not(.qa-icon){background:var(--brand);color:#fff}.drawer-link .d-badge{margin-inline-start:auto;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:var(--danger);color:#fff;font-size:.68rem;font-weight:700;display:grid;place-items:center}.drawer-divider{height:1px;background:var(--border);margin:var(--space-2) var(--space-3)}.drawer-footer{padding:var(--space-3) var(--space-4) calc(var(--space-4) + var(--safe-bottom));display:flex;flex-direction:column;gap:var(--space-2);border-top:1px solid var(--border)}.drawer-footer .theme-toggle{width:100%;justify-content:center}.drawer-footer .theme-toggle button{flex:1;justify-content:center}.theme-toggle{border:1px solid var(--border);border-radius:12px;display:flex;overflow:hidden;background:var(--surface)}.theme-toggle button{border:0;background:transparent;color:var(--text-muted);display:inline-flex;align-items:center;gap:4px;padding:6px 10px;cursor:pointer;font-size:.74rem;font-weight:650}.theme-toggle button.is-active{background:var(--brand);color:#fff}.form{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.form label{display:flex;flex-direction:column;gap:6px}.form label span{font-size:.8rem;color:var(--text-soft);font-weight:600}.form .field-hint{font-size:.72rem;color:var(--text-muted, #999);line-height:1.5;margin-top:-2px}.form input,.form textarea,.form select{width:100%;border:1px solid var(--border-strong);border-radius:14px;background:var(--surface-2);color:var(--text);padding:12px 14px;font-family:inherit;font-size:.9rem;transition:border-color .14s ease,background .14s ease}.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--brand);background:var(--surface);box-shadow:0 0 0 4px var(--brand-soft)}.form textarea{min-height:110px;resize:vertical}.error-text{margin:0;color:var(--danger);font-size:.82rem;font-weight:600}.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:4px;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:6px 12px;font-size:.78rem}.breadcrumb-item-wrap{display:inline-flex;align-items:center;gap:4px}.breadcrumb-item{border:0;background:transparent;color:inherit;font-size:.78rem;cursor:pointer;padding:0}.breadcrumb-item.is-active{color:var(--brand);font-weight:700}.breadcrumb-sep{opacity:.6}.chat-list{display:flex;flex-direction:column;gap:12px}.message-bubble{position:relative;border:1px solid var(--border);border-radius:18px;padding:12px 14px;background:var(--surface-2);max-width:85%;display:flex;flex-direction:column;gap:6px}.message-bubble.is-user{align-self:flex-end;background:var(--brand-grad);color:#fff;border-color:transparent;border-bottom-right-radius:6px}.message-bubble.is-user p,.message-bubble.is-user strong,.message-bubble.is-user small{color:#fff}.message-bubble.is-user small{color:#ffffffc7}.message-bubble.is-admin{align-self:flex-start;background:var(--surface);border-bottom-left-radius:6px}.message-bubble strong{font-size:.78rem;font-weight:700;color:var(--text-muted);display:block}.message-bubble.is-admin strong{color:var(--brand)}.message-bubble p{margin:0;line-height:1.6;font-size:.9rem}.message-bubble small{font-size:.7rem;align-self:flex-end}.quiz-option{display:flex;align-items:center;gap:8px;font-size:.92rem;padding:8px;border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer}.quiz-option:hover{background:var(--brand-soft)}.quiz-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-2)}.quiz-tab{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface-2);color:var(--text-muted);padding:5px 12px;font-size:.78rem;cursor:pointer}.quiz-tab.is-active{border-color:transparent;background:var(--brand);color:#fff}.quiz-result{margin:6px 0;font-size:.86rem;font-weight:650}.quiz-result.is-pass{color:var(--success)}.quiz-result.is-fail{color:var(--danger)}.video-player{width:100%;border-radius:var(--radius-md);margin:var(--space-2) 0;background:#000}.video-hint{margin:4px 0 0;color:var(--text-muted);font-size:.8rem}.attachments-grid{display:flex;flex-wrap:wrap;gap:6px}.attachment-chip{border:1px solid var(--border);background:var(--surface-2);border-radius:var(--radius-pill);padding:5px 12px;font-size:.76rem;color:var(--text-muted)}.skeleton-wrap{display:flex;flex-direction:column;gap:8px}.skeleton-line{height:12px;border-radius:999px;background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 40%,var(--surface-2) 100%);background-size:200% 100%;animation:skeleton-move 1.3s linear infinite}.skeleton-line:nth-child(2n){width:85%}.skeleton-line:nth-child(3n){width:72%}@keyframes skeleton-move{0%{background-position:100% 0}to{background-position:-100% 0}}.auth-layout{min-height:100dvh;display:grid;place-items:center;padding:var(--space-4);background:radial-gradient(900px 500px at 110% -10%,var(--brand-soft),transparent 55%),radial-gradient(700px 400px at -20% 110%,color-mix(in srgb,var(--brand) 18%,transparent),transparent 55%),var(--bg)}.auth-card{width:min(100%,420px);border-radius:var(--radius-lg);padding:var(--space-6);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg)}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:var(--space-4)}.auth-brand-logo{width:min(140px,60%);height:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-brand)}.auth-brand h2{margin:0;font-size:1.35rem;font-weight:800;background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.auth-brand p{font-size:.84rem;color:var(--text-muted);text-align:center;margin:0}.page-state{text-align:center;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5)}.page-state h3{margin:0}.page-state p{color:var(--text-muted)}.empty-graphic{width:64px;height:64px;border-radius:20px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;margin:0 auto}.panel-unread{border-color:color-mix(in srgb,var(--brand) 35%,var(--border));background:linear-gradient(135deg,var(--brand-soft),var(--surface))}.telemetry-meta{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.7rem;color:var(--text-muted);word-break:break-all}.guest-layout{min-height:100dvh;background:radial-gradient(900px 500px at 110% -10%,var(--brand-soft),transparent 55%),radial-gradient(700px 400px at -20% 110%,color-mix(in srgb,var(--brand) 18%,transparent),transparent 55%),var(--bg);padding:16px 16px 32px;overflow-y:auto}.guest-container{max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.guest-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.guest-brand{display:flex;align-items:center;gap:10px}.guest-brand-logo{width:42px;height:42px;border-radius:12px;object-fit:cover}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:16px;animation:fadeIn .15s ease}.dialog-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000059;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.dialog-body{padding:16px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:380px){.quick-actions-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.wallet-hero-balance .amount{font-size:1.8rem}.topbar-greeting strong{max-width:130px;font-size:.88rem}.bottom-nav a span{font-size:.6rem}.shop-metrics{grid-template-columns:1fr 1fr}}@media(max-width:320px){.shop-metrics{grid-template-columns:1fr}.wallet-hero-actions{grid-template-columns:repeat(3,1fr)}}.zanavis-nav{display:flex;flex-direction:column;gap:var(--space-2)}.zanavis-back-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-strong);background:var(--surface);color:var(--brand);border-radius:var(--radius-sm);padding:8px 14px;font-size:.82rem;font-weight:700;cursor:pointer;width:fit-content;transition:background .14s ease,transform .12s ease,box-shadow .14s ease;box-shadow:var(--shadow-xs)}.zanavis-back-btn:hover{background:var(--brand-soft);box-shadow:var(--shadow-sm)}.zanavis-back-btn:active{transform:scale(.97)}.zanavis-breadcrumb .breadcrumb-item{display:inline-flex;align-items:center;gap:4px}.zanavis-cover{border-radius:12px;object-fit:cover;flex-shrink:0;background:var(--surface-3)}.zanavis-banner-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.25;z-index:0}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadeIn .15s ease}.dialog-content{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease;box-shadow:0 -4px 30px #00000040}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.dialog-header h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;margin:0}.dialog-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:grid;place-items:center}.dialog-close:hover{color:var(--text);background:var(--surface-2)}.dialog-pkg-info{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface-2);border-bottom:1px solid var(--border)}.dialog-pkg-info strong{font-size:.9rem}.dialog-pkg-price{font-size:.85rem;font-weight:700;color:var(--brand);direction:ltr}.dialog-body{padding:20px;display:flex;flex-direction:column;gap:12px}.dialog-label{font-size:.88rem;font-weight:600;color:var(--text);margin:0}.dialog-hint{font-size:.78rem;color:var(--text-muted);margin:0}.dialog-error{display:flex;align-items:flex-start;gap:6px;padding:10px 12px;border-radius:var(--radius-sm);background:#ef444414;color:var(--danger, #ef4444);font-size:.82rem;line-height:1.4}.dialog-error svg{flex-shrink:0;margin-top:2px}.dialog-action{margin-top:4px;width:100%;justify-content:center}.dialog-back{width:100%;justify-content:center;font-size:.84rem}.position-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.position-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;transition:border-color .14s ease,background .14s ease}.position-btn:hover:not(.is-disabled){border-color:var(--brand);background:var(--brand-soft)}.position-btn.is-selected{border-color:var(--brand);background:var(--brand-soft);box-shadow:0 0 0 2px #8b5cf633}.position-btn.is-disabled{opacity:.45;cursor:not-allowed}.position-code{font-size:1.1rem;font-weight:800;color:var(--brand)}.position-label{font-size:.78rem;color:var(--text-muted)}.position-badge{font-size:.65rem;padding:1px 6px;border-radius:6px;background:var(--success, #22c55e);color:#fff}.position-hint{font-size:.65rem;color:var(--danger, #ef4444);text-align:center;margin-top:2px}.payment-methods{display:flex;flex-direction:column;gap:10px}.payment-method-btn{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:start;transition:border-color .14s ease,background .14s ease}.payment-method-btn:hover:not(.is-disabled){border-color:var(--brand);background:var(--brand-soft)}.payment-method-btn.is-disabled{opacity:.45;cursor:not-allowed}.pm-icon{width:40px;height:40px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center;color:var(--brand);flex-shrink:0}.pm-text{display:flex;flex-direction:column;gap:2px}.pm-text strong{font-size:.88rem}.pm-text small{font-size:.75rem;color:var(--text-muted)}.pm-text .coming-soon{color:var(--warning, #f59e0b);font-weight:600}.dialog-result{align-items:center;text-align:center;padding:32px 20px}.dialog-result h4{font-size:1.05rem;font-weight:700;margin:0;color:var(--success, #22c55e)}.dialog-result p{font-size:.85rem;color:var(--text-muted);margin:0}.result-icon{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin-bottom:12px}.result-icon.is-success{background:#22c55e1a;color:var(--success, #22c55e)}.spin{animation:spin 1s linear infinite}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);padding:10px 16px;font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:background .12s ease}.btn-ghost:hover{background:var(--surface-2)}.office-link-full{display:flex;align-items:center;gap:14px;width:calc(100% + 32px);margin-inline:-16px;margin-top:14px;padding:18px 20px;border-radius:0;background:linear-gradient(135deg,#6366f11f,#8b5cf614);border:none;border-block:1px solid rgba(99,102,241,.22);text-decoration:none;color:inherit;transition:background .14s ease,box-shadow .14s ease,transform .12s ease;position:relative;overflow:hidden}.office-link-full:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);pointer-events:none}.office-link-full:hover{background:linear-gradient(135deg,#8b5cf624,#6366f11a);box-shadow:0 3px 12px #8b5cf626}.office-link-full:active{transform:scale(.98)}.office-link-full .office-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(145deg,#8b5cf6,#6366f1);display:grid;place-items:center;color:#fff;box-shadow:0 3px 10px #8b5cf64d;flex-shrink:0}.office-link-full .office-text{flex:1;display:flex;flex-direction:column;gap:2px}.office-link-full .office-text strong{font-size:.95rem}.office-link-full .office-text small{font-size:.76rem;color:var(--text-muted)}.purchase-dialog .dialog-header{align-items:flex-start}.purchase-stepper{display:flex;gap:6px;margin-top:8px}.purchase-step{width:28px;height:4px;border-radius:99px;background:var(--surface-3);transition:background .18s ease,transform .18s ease}.purchase-step.is-done,.purchase-step.is-active{background:var(--brand)}.purchase-step.is-active{transform:scaleY(1.35)}.purchase-hero{display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--brand-grad-soft);border-bottom:1px solid var(--border)}.purchase-hero-icon{width:46px;height:46px;border-radius:14px;background:var(--brand-grad);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-brand);flex-shrink:0}.purchase-hero-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.purchase-hero-text strong{font-size:.92rem;line-height:1.35}.purchase-hero-text small{font-size:.74rem;color:var(--text-muted)}.purchase-hero-price{text-align:end;display:flex;flex-direction:column;gap:2px}.purchase-hero-price span{font-size:.92rem;font-weight:800;color:var(--brand)}.purchase-hero-price small{font-size:.72rem;color:var(--text-muted)}.purchase-scope-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:4px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.purchase-scope-tab{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:none;border-radius:calc(var(--radius-sm) - 4px);background:transparent;color:var(--text-muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .14s ease,color .14s ease,box-shadow .14s ease}.purchase-scope-tab.is-active{background:var(--surface);color:var(--brand);box-shadow:var(--shadow-xs)}.purchase-course-list{margin-top:8px;max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2)}.purchase-course-row{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;border:none;border-bottom:1px solid var(--hairline);background:transparent;text-align:start;cursor:pointer;font-size:.8rem;color:inherit}.purchase-course-row:last-child{border-bottom:none}.purchase-course-row.is-selected{background:var(--brand-soft)}.purchase-course-radio{width:14px;height:14px;border-radius:50%;border:2px solid var(--border-strong);flex-shrink:0}.purchase-course-row.is-selected .purchase-course-radio{border-color:var(--brand);background:var(--brand);box-shadow:inset 0 0 0 2px var(--surface)}.purchase-course-title{flex:1;min-width:0}.purchase-course-price{font-size:.72rem;color:var(--text-muted);direction:ltr}.purchase-voucher-field{display:flex;align-items:center;gap:10px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2)}.purchase-voucher-field input{flex:1;border:none;background:transparent;padding:12px 0;font-size:.95rem;font-weight:700;letter-spacing:.08em;color:var(--text)}.purchase-voucher-field input:focus{outline:none}.purchase-voucher-status{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border-radius:var(--radius-sm);font-size:.8rem;line-height:1.45}.purchase-voucher-status.is-valid{background:var(--success-soft);color:var(--success)}.purchase-voucher-status.is-invalid{background:var(--danger-soft);color:var(--danger)}.purchase-summary-card{padding:12px 14px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;font-size:.82rem}.purchase-summary-card .row{display:flex;justify-content:space-between;gap:10px;color:var(--text-muted)}.purchase-summary-card .row strong{color:var(--text);font-weight:700;text-align:end}.payment-method-btn.is-selected{border-color:var(--brand);background:var(--brand-soft)}
