:root{--color-bg:#0d1117;--color-surface:#161b22;--color-surface-hover:#1c2128;--color-accent:#f0a500;--color-accent-dim:#b87d00;--color-accent-glow:#f0a50040;--color-text:#f5f0e8;--color-text-muted:#f5f0e88c;--color-border:#f0a5002e;--color-border-strong:#f0a50080;--color-danger:#e05252;--color-success:#52c97a;--color-overlay:#000000b8;--font-display:"Boogaloo", cursive;--font-ui:"Space Grotesk", sans-serif;--font-joke:"Lora", Georgia, serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-pill:999px;--shadow-card:0 1px 3px #0006, 0 0 0 1px var(--color-border);--shadow-card-hover:0 4px 16px #00000080, 0 0 0 1px var(--color-border-strong), 0 0 20px var(--color-accent-glow);--shadow-modal:0 8px 40px #0009, 0 0 0 1px var(--color-border);--transition-fast:.15s ease;--transition-base:.22s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-ui);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}a{color:var(--color-accent);text-underline-offset:3px;transition:color var(--transition-fast);text-decoration:underline}a:hover{color:var(--color-text)}.container{max-width:860px;min-height:100vh;padding:var(--space-6) var(--space-5);flex-direction:column;margin:0 auto;display:flex}.content{gap:var(--space-7);flex-direction:column;flex:1;display:flex}.header{flex-direction:column;align-items:center;width:100%;display:flex}.header-top{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;width:100%;display:flex}@media (width<=420px){.header-top{flex-direction:column;align-items:center}}.header h1{font-family:var(--font-display);color:var(--color-accent);letter-spacing:.01em;text-align:center;font-size:clamp(2.8rem,8vw,4.5rem);font-weight:400;line-height:1}.auth-area{align-items:center;gap:var(--space-2);flex-direction:row;display:flex}.auth-user{font-family:var(--font-ui);color:var(--color-text-muted);font-size:.78rem}button{font-family:var(--font-ui);cursor:pointer;border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text);transition:background var(--transition-base), color var(--transition-base), box-shadow var(--transition-base);touch-action:manipulation;-webkit-tap-highlight-color:transparent;border:none;font-weight:600}button:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.btn-auth,.btn-favourites{border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text);letter-spacing:.02em;padding:.35em 1em;font-size:.78rem}.btn-auth:hover,.btn-favourites:hover{background:var(--color-surface-hover);border-color:var(--color-border-strong)}.category-grid{gap:var(--space-3);grid-template-columns:repeat(3,1fr);width:100%;display:grid}.category-card{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:90px;box-shadow:var(--shadow-card);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:box-shadow var(--transition-base), border-color var(--transition-base), background var(--transition-base);will-change:transform;flex-direction:column;display:flex}.category-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.category-card:hover,.category-card:focus-visible{background:var(--color-surface-hover);box-shadow:var(--shadow-card-hover);border-color:var(--color-border-strong)}.category-card--active{background:var(--color-surface-hover);border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent), 0 0 24px var(--color-accent-glow)}.category-card:disabled{opacity:.5;cursor:not-allowed}.category-card__emoji{font-size:1.8rem;line-height:1}.category-card__label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.8rem;font-weight:700}.category-card--active .category-card__label{color:var(--color-accent)}.joke-stage{min-height:200px;padding:var(--space-7) var(--space-5);text-align:center;border-radius:var(--radius-lg);background:radial-gradient(ellipse 70% 60% at 50% 30%, #f0a5000f 0%, transparent 70%), var(--color-surface);border:1px solid var(--color-border);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative}.joke-empty{align-items:center;gap:var(--space-3);color:var(--color-text-muted);flex-direction:column;display:flex}.joke-empty__icon{opacity:.5;font-size:2.5rem}.joke-empty__text{font-family:var(--font-ui);font-size:.95rem;font-style:italic}.joke-text{width:100%}.joke-setup{font-family:var(--font-joke);color:var(--color-text-muted);margin-bottom:var(--space-5);font-size:clamp(1.1rem,2.5vw,1.35rem);font-style:italic;line-height:1.6}.joke-punchline{font-family:var(--font-joke);color:var(--color-text);font-size:clamp(1.4rem,4vw,2.1rem);font-style:italic;font-weight:600;line-height:1.45}.loading-dots{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4);display:flex}.loading-dots span{background:var(--color-accent);border-radius:50%;width:10px;height:10px;display:inline-block}.joke-actions{margin-top:var(--space-5);align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.btn-save-favourite{border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);color:var(--color-accent);letter-spacing:.03em;transition:background var(--transition-base), box-shadow var(--transition-base);will-change:transform;background:0 0;padding:.55em 1.5em;font-size:.9rem;font-weight:600}.btn-save-favourite:hover{background:var(--color-accent-glow);box-shadow:0 0 16px var(--color-accent-glow)}.saved-confirmation{font-family:var(--font-ui);color:var(--color-success);letter-spacing:.02em;font-size:.85rem}.modal-overlay{background:var(--color-overlay);z-index:1000;padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);padding:var(--space-6);text-align:center;width:100%;max-width:420px;color:var(--color-text)}.modal h4{font-family:var(--font-ui);margin-bottom:var(--space-5);color:var(--color-text);font-size:1rem;font-weight:600;line-height:1.5}.modal-buttons{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.btn-cancel{border:1px solid var(--color-border);background:var(--color-surface-hover);border-radius:var(--radius-pill);padding:.5em 1.3em;font-size:.85rem}.btn-cancel:hover{border-color:var(--color-border-strong)}.btn-confirm{border:1px solid var(--color-danger);color:var(--color-danger);border-radius:var(--radius-pill);background:0 0;padding:.5em 1.3em;font-size:.85rem}.btn-confirm:hover{background:#e0525226}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);padding:var(--space-6);position:relative}.favourites-panel{flex-direction:column;align-items:stretch;width:100%;min-width:340px;max-width:90vw;max-height:80vh;overflow-y:auto}.close-modal{top:var(--space-3);right:var(--space-4);cursor:pointer;color:var(--color-text-muted);padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;font-size:1.4rem;line-height:1;position:absolute}.close-modal:hover{color:var(--color-text)}.favourites-title{font-family:var(--font-display);color:var(--color-accent);margin-bottom:var(--space-5);font-size:1.6rem;font-weight:400}.favourites-empty{color:var(--color-text-muted);font-size:.9rem;line-height:1.6}.favourite-item{border-bottom:1px solid var(--color-border);padding:var(--space-4) 0}.favourite-item:last-child{border-bottom:none}.favourite-setup{font-family:var(--font-joke);color:var(--color-text-muted);margin-bottom:var(--space-2);font-size:.9rem;font-style:italic;line-height:1.5}.favourite-punchline{font-family:var(--font-joke);color:var(--color-text);margin-bottom:var(--space-3);font-size:1rem;font-style:italic;font-weight:600;line-height:1.5}.favourite-meta{align-items:center;gap:var(--space-3);display:flex}.favourite-category{font-size:.72rem;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600}.btn-remove-favourite{color:var(--color-danger);border-radius:var(--radius-pill);background:0 0;border:1px solid #e0525266;padding:.2em .7em;font-size:.72rem}.btn-remove-favourite:hover{border-color:var(--color-danger);background:#e052521f}.install-modal{text-align:left;max-width:400px}.install-modal h4{color:var(--color-accent);margin-bottom:var(--space-4);padding-right:var(--space-5);font-size:1rem;font-weight:700}.install-modal__body{font-family:var(--font-ui);color:var(--color-text-muted);font-size:.9rem;line-height:1.6}.install-modal__steps{gap:var(--space-3);counter-reset:steps;flex-direction:column;list-style:none;display:flex}.install-modal__steps li{counter-increment:steps;gap:var(--space-3);font-family:var(--font-ui);color:var(--color-text);font-size:.9rem;line-height:1.5;display:flex}.install-modal__steps li:before{content:counter(steps);background:var(--color-accent);width:22px;height:22px;color:var(--color-bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:.72rem;font-weight:700;display:flex}.footer{align-items:center;gap:var(--space-3);padding-top:var(--space-6);color:var(--color-text-muted);font-size:.78rem;font-family:var(--font-ui);text-align:center;flex-direction:column;display:flex}.btn-install{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-pill);padding:.45em 1.2em;font-size:.8rem}.btn-install:hover{border-color:var(--color-border-strong);background:var(--color-surface-hover)}@media (width<=480px){.container{padding:var(--space-5) var(--space-4);gap:var(--space-5)}.content{gap:var(--space-5)}.category-grid{gap:var(--space-2);grid-template-columns:repeat(2,1fr)}.category-card{min-height:80px;padding:var(--space-3) var(--space-2)}.joke-stage{padding:var(--space-5) var(--space-4);min-height:160px}.modal{padding:var(--space-5)}.modal-buttons{flex-direction:column}.btn-cancel,.btn-confirm{width:100%}}
