*,:before,:after{box-sizing:border-box}:root{--bg:#0f172a;--surface:#1e293b;--surface2:#334155;--border:#475569;--text:#f1f5f9;--muted:#94a3b8;--accent:#3b82f6;--accent2:#8b5cf6;--success:#22c55e;--error:#ef4444;--radius:12px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5}body{min-height:100vh;margin:0}#app{max-width:960px;margin:0 auto;padding:1.5rem 1rem 4rem}h1,h2,h3{line-height:1.2}.app-header{text-align:center;margin-bottom:2rem;padding:1.5rem 0 0}.app-header .logo{letter-spacing:-.5px;background:linear-gradient(135deg, var(--accent), var(--accent2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800}.tagline{color:var(--muted);margin:.25rem 0 0;font-size:.9rem}.gen-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:1.5rem;padding:1.75rem;display:flex}.gen-form h2{margin:0 0 .25rem;font-size:1.25rem}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:600}.field-hint{color:var(--muted);margin:0;font-size:.8rem}select,.text-input{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:8px;outline:none;width:100%;padding:.6rem .9rem;font-family:inherit;font-size:.95rem;transition:border-color .2s}select:focus,.text-input:focus{border-color:var(--accent)}.checkbox-grid{flex-wrap:wrap;gap:.45rem;display:flex}.chip{background:var(--surface2);border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.82rem;transition:background .15s,border-color .15s;display:inline-flex}.chip input[type=checkbox]{display:none}.chip:has(input:checked){border-color:var(--accent);background:color-mix(in srgb, var(--accent) 20%, transparent)}.type-chip{border-color:var(--type-color,var(--border))}.type-chip:has(input:checked){background:color-mix(in srgb, var(--type-color,var(--accent)) 30%, transparent);border-color:var(--type-color,var(--accent))}button{cursor:pointer;font-family:inherit}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;border:none;border-radius:8px;align-self:flex-start;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-surprise{color:#fff;letter-spacing:.01em;white-space:nowrap;background:linear-gradient(135deg,#f59e0b,#ef4444);border:none;border-radius:10px;padding:.8rem 1.75rem;font-size:1.05rem;font-weight:700;transition:opacity .15s,transform .12s}.btn-surprise:hover{opacity:.9;transform:translateY(-2px)scale(1.02)}.btn-surprise:active{transform:translateY(0)scale(1)}.surprise-row{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.surprise-hint{color:var(--muted);font-size:.82rem;font-style:italic}.form-divider{color:var(--muted);align-items:center;gap:.75rem;font-size:.8rem;display:flex}.form-divider:before,.form-divider:after{content:"";background:var(--border);flex:1;height:1px}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.5rem 1.1rem;font-size:.9rem;transition:border-color .15s}.btn-secondary:hover{border-color:var(--accent)}.mode-picker{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.btn-mode{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);flex-direction:column;align-items:center;gap:.4rem;padding:1.5rem 2.5rem;font-size:1rem;font-weight:600;transition:border-color .15s,background .15s;display:flex}.btn-mode:hover{border-color:var(--accent);background:var(--surface2)}.btn-mode .btn-icon{font-size:2rem}.deck-preview{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.dobble-card{border-radius:50%;display:block}.dobble-card--active circle:first-of-type{filter:drop-shadow(0 0 8px var(--accent))}.dobble-symbol{transform-box:fill-box;transform-origin:50%}.dobble-symbol:hover{animation:.9s ease-in-out infinite symbol-hover-pulse}.dobble-symbol--match circle{animation:.5s ease-out pulseMatch}@keyframes symbol-hover-pulse{0%{transform:scale(1)}50%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes pulseMatch{0%{r:attr(r)}50%{transform:scale(1.25)}to{transform:scale(1)}}.game-ui{z-index:10;background:var(--bg);grid-template-rows:auto 1fr;gap:.75rem;padding:.75rem 1rem 1rem;display:grid;position:fixed;inset:0;overflow:hidden}.game-hud{background:var(--surface);border-radius:var(--radius);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:1rem;padding:.6rem 1.25rem;display:flex}.hud-score{font-size:1.1rem;font-weight:700}.hud-timer{font-variant-numeric:tabular-nums;color:var(--muted);margin-left:auto}.game-cards{grid-template-rows:2fr 3fr;place-items:center;gap:.75rem;min-height:0;display:grid;overflow:hidden}.card-wrapper{flex-direction:column;align-items:center;gap:.25rem;width:100%;height:100%;min-height:0;display:flex}.game-cards .dobble-card{flex:1;min-height:0;display:block;width:auto!important;max-width:calc(100vw - 2rem)!important;height:100%!important}.card-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;order:-1;margin:0;font-size:.75rem}.card-wrapper--pile .dobble-card{pointer-events:none;cursor:default;filter:drop-shadow(5px 5px #ffffff4d)drop-shadow(10px 10px #ffffff26)drop-shadow(0 2px 12px #00000073)}@keyframes symbol-nudge{0%{transform:scale(1)}20%{transform:scale(1.4)}50%{transform:scale(1.15)}75%{transform:scale(1.35)}to{transform:scale(1)}}.symbol-nudge{transform-box:fill-box;transform-origin:50%;animation:.3s ease-in-out symbol-nudge}.game-msg{pointer-events:none;z-index:100;border-radius:999px;padding:.75rem 2rem;font-size:1rem;font-weight:600;animation:.25s ease-out fadeUp;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.game-msg.hidden{display:none}.game-flash.flash-success{background:var(--success);color:#fff}.game-flash.flash-error{background:var(--error);color:#fff}.game-over{pointer-events:all;background:#0f172ad9;border-radius:0;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;font-size:1.1rem;animation:none;display:flex;position:fixed;inset:0;transform:none}.game-over h2{font-size:2rem}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.loader{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:40vh;padding:4rem 2rem;display:flex}.loader-spinner{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loader-bar{background:var(--surface2);border-radius:999px;width:260px;height:8px;overflow:hidden}.loader-bar-fill{background:linear-gradient(90deg, var(--accent), var(--accent2));border-radius:999px;height:100%;transition:width .3s}.loader-pct{color:var(--muted);font-size:.85rem}.error-banner{background:color-mix(in srgb, var(--error) 20%, var(--surface));border:1px solid var(--error);border-radius:var(--radius);flex-direction:column;gap:.75rem;max-width:600px;margin:2rem auto;padding:1.25rem 1.5rem;display:flex}.print-toolbar{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.print-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));justify-items:center;gap:1rem;display:grid}@media print{:root{color:#000;background:#fff}.no-print{display:none!important}.print-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.dobble-card circle:first-of-type{stroke:#000!important}}@media (width<=600px){.gen-form{padding:1.25rem}.btn-mode{padding:1rem 1.75rem}}
