*,:before,:after{box-sizing:border-box}html,body{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-family:var(--app-font,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Inter,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol");background:var(--bg-main);color:var(--text-primary);margin:0;line-height:1.5}img,svg,video,canvas,audio,iframe,embed,object{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 .5rem;font-weight:800}p{margin:0 0 1rem}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit}:focus-visible{outline:3px solid color-mix(in srgb,var(--primary),white 50%);outline-offset:2px}:root{--primary:#2563eb;--primary-dark:#1e40af;--primary-hover:#1d4ed8;--primary-alpha:#2563eb26;--secondary:#7c3aed;--secondary-hover:#6d28d9;--accent:#0ea5e9;--accent-hover:#0284c7;--success:#16a34a;--success-hover:#15803d;--success-alpha:#16a34a1f;--warning:#f59e0b;--warning-hover:#d97706;--warning-alpha:#f59e0b24;--danger:var(--danger);--danger-hover:#dc2626;--danger-alpha:#ef44441f;--info:#4f46e5;--info-alpha:#4f46e51f;--bg-main:#fff;--bg-soft:#f8fafc;--bg-hover:#f1f5f9;--card-bg:#fff;--border-color:#e5e7eb;--border-color-light:#eceff3;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-on-primary:#fff;--shadow-sm:0 1px 2px #0f172a0a;--shadow-md:0 6px 16px #0f172a14;--shadow-lg:0 10px 28px #0f172a1f;--radius-xl:20px;--radius-lg:16px;--radius-md:12px;--radius-sm:var(--radius-md);--app-font:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Inter,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";--font-headings:"Inter",var(--app-font);--brand:var(--primary);--brand-600:var(--primary-hover);--brand-700:var(--primary-dark);--ok:var(--success);--warn:var(--warning);--bg:var(--bg-main);--surface:var(--card-bg);--panel:var(--card-bg);--text:var(--text-primary);--muted:var(--text-muted);--border:var(--border-color);--ring:0 0 0 3px var(--primary-alpha);--shadow:var(--shadow-md);--radius:var(--radius-lg);--radius-xs:var(--radius-sm);--card-padding:1rem;--card-shadow:var(--shadow-sm);--deck-gap:.75rem;--font:var(--app-font)}html[data-theme=dark]{--bg-main:#0b1220;--bg-soft:#0f172a;--bg-hover:#172036;--card-bg:#0f1626;--border-color:#1e2a44;--border-color-light:#22304f;--text-primary:#e5ecff;--text-secondary:#c7d2fe;--text-muted:#95a2c9;--shadow-sm:0 1px 2px #02061766;--shadow-md:0 6px 16px #02061799;--shadow-lg:0 10px 28px #020617b3}.container{width:100%;max-width:1200px;margin-inline:auto;padding-inline:1rem}.grid{display:grid}.flex{display:flex}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-0{margin-bottom:0}.m-0{margin:0}.p-0{padding:0}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.hidden{display:none}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@media (min-width:640px){[class~=sm\:grid-cols-2]{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:768px){[class~=md\:grid-cols-2]{grid-template-columns:repeat(2,minmax(0,1fr))}[class~=md\:grid-cols-3]{grid-template-columns:repeat(3,minmax(0,1fr))}[class~=md\:flex]{display:flex}}@media (min-width:1024px){[class~=lg\:grid-cols-3]{grid-template-columns:repeat(3,minmax(0,1fr))}[class~=lg\:grid-cols-4]{grid-template-columns:repeat(4,minmax(0,1fr))}}.page-title{font-size:clamp(1.5rem,2vw + .5rem,2rem);font-weight:900}.page-subtitle{color:var(--text-muted)}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1rem}.card:hover{box-shadow:var(--shadow-md)}.card.headered>.card-header{border-bottom:1px solid var(--border-color-light);justify-content:space-between;align-items:center;gap:.75rem;padding-bottom:.75rem;display:flex}.card .card-title{font-weight:800}.btn{cursor:pointer;color:var(--text-primary);background:var(--bg-soft);border:none;border:1px solid var(--border-color);border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1rem;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .2s,background .2s,color .2s,border-color .2s;display:inline-flex}.btn:hover{background:var(--bg-hover);border-color:color-mix(in srgb,var(--primary),white 40%);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.small,.btn-small{border-radius:8px;padding:.45rem .7rem;font-size:.9rem}.btn-primary,.btn.primary{background:var(--primary);color:var(--text-on-primary);border-color:#0000}.btn-primary:hover,.btn.primary:hover{background:var(--primary-hover)}.btn-secondary,.btn.secondary{background:var(--bg-soft);color:var(--text-primary);border:1px solid var(--border-color)}.btn-success,.btn.success{background:var(--success);color:#fff;border-color:#0000}.btn-success:hover,.btn.success:hover{background:var(--success-hover)}.btn-danger,.btn.danger{background:var(--danger);color:#fff;border-color:#0000}.btn-danger:hover,.btn.danger:hover{background:var(--danger-hover)}.btn-outline{color:var(--primary);border:1px solid color-mix(in srgb,var(--primary),black 10%);background:0 0}.btn-outline:hover{background:color-mix(in srgb,var(--primary),white 90%)}.btn-ghost{color:var(--text-secondary);border:1px dashed var(--border-color);background:0 0}.btn-ghost:hover{background:var(--bg-soft)}.btn.icon{place-items:center;width:36px;height:36px;padding:0;display:inline-grid}.input{background:var(--bg-soft);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;padding:.6rem .75rem;box-shadow:inset 0 1px #0f172a05}.input:focus-within,.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-alpha);outline:none}.input>input,.input>select,.input>textarea{color:inherit;width:100%;font:inherit;background:0 0;border:0;outline:none}input.input,select.input,textarea.input{width:100%}.input-group{border:1px solid var(--border-color);background:var(--bg-soft);border-radius:10px;display:flex;overflow:hidden}.input-group>.input{border:none;border-radius:0;flex:1}.input-addon{color:var(--text-muted);align-items:center;padding:.6rem .75rem;display:inline-flex}.label{color:var(--text-primary);margin-bottom:.35rem;font-size:.9rem;font-weight:700}.help{color:var(--text-muted);font-size:.85rem}.input.is-error,.is-error.input{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-alpha)}.input.is-success,.is-success.input{border-color:var(--success);box-shadow:0 0 0 3px var(--success-alpha)}.badge{background:var(--bg-soft);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:999px;align-items:center;gap:.35rem;padding:.25rem .55rem;font-size:.8rem;font-weight:800;display:inline-flex}.badge.ok{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.badge.warn{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.badge.info{color:#3730a3;background:#eef2ff;border-color:#c7d2fe}.badge.muted{color:#374151;background:#f3f4f6;border-color:#e5e7eb}.table{border-collapse:separate;border-spacing:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.table th,.table td{text-align:left;padding:.75rem .9rem}.table thead th{background:color-mix(in srgb,var(--bg-soft),white 50%);color:var(--text-secondary);border-bottom:1px solid var(--border-color);font-weight:800}.table tbody tr+tr td{border-top:1px solid var(--border-color-light)}.table tbody tr:hover{background:var(--bg-soft)}.table-wrap{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}.tabs{background:var(--bg-soft);border:1px solid var(--border-color);border-radius:999px;flex-wrap:wrap;gap:.4rem;padding:.25rem;display:flex}.tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;padding:.5rem .9rem;font-weight:800}.tab:hover{border-color:var(--border-color);background:#fff}.tab.active{border-color:var(--border-color);color:var(--text-primary);background:#fff}.alert{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-soft);color:var(--text-secondary);align-items:flex-start;gap:.6rem;padding:.8rem 1rem;display:flex}.alert.ok{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.alert.warn{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.alert.info{color:#3730a3;background:#eef2ff;border-color:#c7d2fe}.alert.danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.modal{z-index:50;background:#0006;place-items:center;display:grid;position:fixed;inset:0}.modal-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:min(720px,92vw);box-shadow:var(--shadow-lg);overflow:hidden}.modal-card .modal-head{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;justify-content:space-between;align-items:center;padding:1rem;display:flex}.modal-card .modal-body{padding:1rem}.modal-card .modal-foot{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.5rem;padding:1rem;display:flex}@media (max-width:768px){.modal{place-items:end}.modal-card{border-radius:16px 16px 0 0;width:100%}}.toast-viewport{z-index:60;gap:.6rem;display:grid;position:fixed;bottom:16px;right:16px}.toast{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--card-bg);box-shadow:var(--shadow-md);grid-template-columns:auto 1fr auto;align-items:center;gap:.6rem;min-width:260px;padding:.7rem .9rem;display:grid}.toast.ok{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.toast.warn{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.toast.info{color:#3730a3;background:#eef2ff;border-color:#c7d2fe}.toast.danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.toast .toast-close{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none}.toast .toast-close:hover{opacity:1}.skeleton{background:color-mix(in srgb,var(--border-color),white 10%);border-radius:6px;min-height:1rem;position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--bg-hover),white 20%),transparent);animation:1.6s infinite skel;position:absolute;inset:0}@keyframes skel{0%{transform:translate(-100%)}to{transform:translate(100%)}}.page-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;margin-bottom:1rem;padding:1rem}.page-header .header-content{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.page-header .header-title{align-items:center;gap:.5rem;display:flex}.page-header .title-indicator{opacity:.8;background:#fff;border-radius:999px;width:10px;height:10px}.muted{color:var(--text-muted)}.soft{background:var(--bg-soft)}.hr{background:var(--border-color-light);border:0;height:1px;margin:.75rem 0}.kbd{border:1px solid var(--border-color);background:var(--bg-soft);min-width:1.5rem;height:1.5rem;color:var(--text-secondary);border-radius:6px;place-items:center;padding:0 .35rem;font-size:.8rem;font-weight:700;display:inline-grid}.announcements-page .announcements-grid{grid-template-columns:1fr;align-items:start;gap:16px;display:grid}.announcements-page .announcements-grid>.card{min-height:0}@media (min-width:1024px){.announcements-page .announcements-grid.with-form{grid-template-columns:2fr 3fr 2fr}.announcements-page .announcements-grid:not(.with-form){grid-template-columns:2fr 3fr}}.announcement-list{flex-direction:column;gap:10px;display:flex}.announcement-list-item{border:1px solid var(--border-color,#0f172a14);cursor:pointer;border-radius:12px;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.announcement-list-item.active{border-color:#2563eb59;box-shadow:0 6px 16px #2563eb2e}.announcement-body{white-space:pre-wrap;font-size:1rem;line-height:1.6}[class^=i-lucide-],[class*=\ i-lucide-]{width:1em;height:1em;display:inline-block}@media print{.page-header,.toast-viewport,.modal,.modal-backdrop{display:none!important}body{color:#000!important;background:#fff!important}a{text-decoration:underline;color:#000!important}.card{box-shadow:none!important;border-color:#ccc!important}}
:root{--ds-card-radius:var(--radius,16px);--ds-card-padding:var(--card-padding,1rem);--ds-card-shadow:var(--card-shadow,0 6px 18px #0f172a14);--ds-btn-radius:10px;--ds-btn-padding:.65rem 1rem;--ds-btn-font:.95rem;--ds-badge-radius:999px}.btn,.btn-ghost,.btn-outline{font-size:var(--ds-btn-font);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;text-decoration:none;transition:transform .15s,box-shadow .2s,background .2s,border-color .2s,color .2s;display:inline-flex;border-radius:var(--ds-btn-radius)!important;padding:var(--ds-btn-padding)!important;font-weight:700!important}.btn{box-shadow:0 4px 14px #0f172a14;background:var(--bg-soft)!important;border-color:var(--border-color,var(--border,#02061714))!important;color:var(--text-primary,var(--text,#0f172a))!important}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:focus-visible{box-shadow:var(--ring,0 0 0 3px #2563eb40);outline:none}.btn[disabled]{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn-primary,.btn.primary{box-shadow:0 8px 20px #2563eb40;background:var(--brand,var(--primary))!important;border-color:color-mix(in oklab,var(--brand,var(--primary)),#0000001f)!important;color:var(--text-on-primary,#fff)!important}.btn-primary:hover,.btn.primary:hover{background:var(--brand-600,var(--primary-hover))!important}.btn-secondary,.btn.secondary{background:var(--surface,var(--card-bg))!important;border-color:var(--border-color,var(--border,#0206171f))!important;color:var(--text,var(--text-primary))!important}.btn-danger,.btn.danger{background:var(--danger,#ef4444)!important;border-color:color-mix(in srgb,var(--danger,#ef4444),black 10%)!important;color:#fff!important}.btn-success,.btn.success{background:var(--ok,#10b981)!important;border-color:color-mix(in srgb,var(--ok,#10b981),black 10%)!important;color:#fff!important}.btn-outline{color:var(--brand,var(--primary))!important;border-color:color-mix(in srgb,var(--brand,var(--primary)),black 12%)!important;background:0 0!important}.btn-outline:hover{background:color-mix(in srgb,var(--brand,var(--primary)),white 88%)!important}.btn-ghost{color:var(--text-secondary,var(--muted))!important;border-color:color-mix(in srgb,var(--text-secondary,var(--muted)),transparent 60%)!important;background:#0f172a08!important}.btn-ghost:hover{background:#0f172a0f!important}.btn-sm,.btn.small{font-size:.82rem;border-radius:8px!important;padding:.4rem .75rem!important}.btn-lg{font-size:1rem;border-radius:12px!important;padding:.85rem 1.25rem!important}.btn-block{width:100%;display:flex!important}.card{color:var(--text,var(--text-primary));background:var(--surface,var(--card-bg))!important;border-radius:var(--ds-card-radius)!important;border:1px solid var(--border-color,var(--border,#0f172a14))!important;padding:var(--ds-card-padding)!important;box-shadow:var(--ds-card-shadow)!important}.card h3,.card .card-title{color:inherit;margin-block:0 .35rem;font-size:1.05rem;font-weight:800}.card-muted{color:var(--muted)}.deck{gap:var(--deck-gap,.75rem);flex-direction:column;display:flex;background:var(--surface,var(--card-bg))!important;border:1px solid var(--border-color,var(--border,#0f172a14))!important;border-radius:var(--ds-card-radius)!important;padding:var(--ds-card-padding)!important;box-shadow:var(--ds-card-shadow)!important}.deck-header{border-bottom:1px solid color-mix(in srgb,var(--border-color,var(--border,#0f172a14)),transparent 20%);justify-content:space-between;align-items:center;gap:.5rem;padding-bottom:.35rem;display:flex}.deck-title{color:var(--text,var(--text-primary));margin:0;font-size:1.05rem;font-weight:800}.deck-content{flex-direction:column;gap:.65rem;display:flex}.badge{border-radius:var(--ds-badge-radius);align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:.78rem;font-weight:700;display:inline-flex;border:1px solid var(--border-color,var(--border,#0f172a1f))!important;background:var(--bg-soft)!important;color:var(--text-secondary,var(--muted))!important}.badge.sa{color:#fff!important;background:#111827!important;border-color:#111827!important}.badge.admin{color:#fff!important;background:#1f2937!important;border-color:#1f2937!important}.badge.teacher{color:#fff!important;background:#0ea5e9!important;border-color:#0ea5e9!important}.badge.student{color:#fff!important;background:#6366f1!important;border-color:#6366f1!important}.input,.select,.textarea{width:100%;font:inherit;border-radius:10px;transition:border-color .15s,box-shadow .2s,background .2s;border:1px solid var(--border-color,#d7dce5)!important;background:var(--surface,var(--card-bg))!important;color:var(--text,var(--text-primary))!important;padding:.65rem .85rem!important}.textarea{resize:vertical;min-height:110px}.input::-moz-placeholder{color:color-mix(in srgb,var(--muted),transparent 30%)}.textarea::-moz-placeholder{color:color-mix(in srgb,var(--muted),transparent 30%)}.input::placeholder,.textarea::placeholder{color:color-mix(in srgb,var(--muted),transparent 30%)}.input:focus,.select:focus,.textarea:focus{box-shadow:var(--ring,0 0 0 3px #2563eb40);outline:none;border-color:color-mix(in srgb,var(--brand,var(--primary)),white 30%)!important}.table{border-collapse:separate;border-spacing:0;width:100%;box-shadow:var(--ds-card-shadow);overflow:hidden;border:1px solid var(--border-color,var(--border,#0f172a1a))!important;border-radius:var(--ds-card-radius)!important;background:var(--surface,var(--card-bg))!important}.table th,.table td{border-bottom:1px solid var(--border-color,#0f172a14);text-align:left;padding:.75rem .95rem}.table thead th{background:color-mix(in srgb,var(--bg-soft),white 30%);color:var(--text-secondary,var(--muted));font-weight:700}.table tbody tr:hover td{background:color-mix(in srgb,var(--bg-soft),white 12%)}.table-wrap{border-radius:var(--ds-card-radius);box-shadow:var(--ds-card-shadow);overflow-x:auto}.card-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;display:grid}.muted{color:var(--muted)}@media (max-width:720px){.card,.deck{border-radius:14px!important;padding:.85rem!important}.btn{width:100%}}
:root{--g-card:#ffffffc7;--g-card-hov:#ffffffeb;--g-sidebar:#ffffffb8;--g-topbar:#ffffffad;--g-panel:#ffffffe0;--g-input:#fff9;--g-border:#ffffffe6;--g-shadow:0 12px 40px #00000014,0 2px 12px #0000000a;--g-shadow-hov:0 20px 60px #0000001f,0 4px 20px #00000014;--t1:#1c1917;--t2:#57534e;--t3:#a8a29e;--t4:#d6d3d1;--amber:#f59e0b;--amber2:#fbbf24;--teal:#0d9488;--rose:#e11d48;--indigo:#4f46e5;--sage:#4d7c52;--sidebar-w:230px;--topbar-h:58px}.bg-canvas{z-index:-1;background:var(--bg-main,linear-gradient(135deg,#fef3c7 0%,#fde68a 30%,#d1fae5 65%,#a7f3d0 100%));background-position:50%;background-size:cover;transition:background .5s;position:fixed;inset:0}.bg-canvas:after{content:"";-webkit-backdrop-filter:blur(var(--bg-blur,0px));backdrop-filter:blur(var(--bg-blur,0px));background:#ffffff1f;position:absolute;inset:0}.bg-grain{z-index:-1;pointer-events:none;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px;position:fixed;inset:0}.premium-sidebar{background:var(--g-sidebar)!important;-webkit-backdrop-filter:blur(24px)saturate(180%)!important;backdrop-filter:blur(24px)saturate(180%)!important;border-right:1px solid var(--g-border)!important}.premium-topbar{background:var(--g-topbar)!important;-webkit-backdrop-filter:blur(20px)saturate(160%)!important;backdrop-filter:blur(20px)saturate(160%)!important;border-bottom:1px solid #ffffffb3!important}.stile{background:var(--g-card);-webkit-backdrop-filter:blur(16px)saturate(160%);backdrop-filter:blur(16px)saturate(160%);border:1px solid var(--g-border);box-shadow:var(--g-shadow);border-radius:16px;align-items:center;gap:14px;padding:18px 20px;transition:all .2s;display:flex}.stile:hover{box-shadow:var(--g-shadow-hov);transform:translateY(-2px)}.hero-card{background:var(--g-card);-webkit-backdrop-filter:blur(20px)saturate(180%);backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--g-border);box-shadow:var(--g-shadow);border-radius:20px;padding:24px;position:relative;overflow:hidden}.tcard{background:var(--g-card);-webkit-backdrop-filter:blur(18px)saturate(160%);backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--g-border);box-shadow:var(--g-shadow);cursor:pointer;border-radius:18px;transition:all .22s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.tcard:hover{box-shadow:var(--g-shadow-hov);background:var(--g-card-hov);transform:translateY(-4px)scale(1.008)}.ring-wrap{flex-shrink:0;width:64px;height:64px;position:relative}.ring-wrap svg{transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#0000000f;stroke-width:5px}.ring-fill{fill:none;stroke-width:5px;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.34,1.56,.64,1)}.ring-fill.col-red{stroke:#f43f5e}.ring-fill.col-amber{stroke:#f59e0b}.ring-fill.col-green{stroke:#10b981}.btn-premium{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .18s;display:inline-flex}.btn-glass{color:var(--t2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff8c;border:1px solid #fffc}.btn-amber{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 14px #f59e0b59}.font-playfair{font-family:Playfair Display,serif}.font-jakarta{font-family:Plus Jakarta Sans,sans-serif}
