.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#f5f0e8,#e8e0d0,#f0ece4)}.login-bg-shapes{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3}.shape-1{width:500px;height:500px;background:#2e7d4f;top:-150px;right:-120px;animation:float 12s ease-in-out infinite}.shape-2{width:400px;height:400px;background:#d4903a;bottom:-120px;left:-100px;animation:float 15s ease-in-out infinite reverse}.shape-3{width:300px;height:300px;background:#c0392b;top:50%;left:20%;animation:float 18s ease-in-out infinite;opacity:.15}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.03)}}.login-container{text-align:center;z-index:1;width:100%;max-width:440px;padding:var(--space-lg)}.login-logo{font-size:4rem;margin-bottom:var(--space-md);animation:float 6s ease-in-out infinite}.login-title{font-size:3.2rem;font-weight:800;background:linear-gradient(135deg,#2e7d4f,#1a5c38 40%,#d4903a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-xs);letter-spacing:-.5px}.login-subtitle{color:var(--color-text-secondary);font-size:1.05rem;margin-bottom:var(--space-xl);font-weight:400}.login-card{padding:var(--space-xl) var(--space-lg);background:#ffffffd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,.06);border-radius:24px;box-shadow:0 8px 32px #0000000f}.btn-google{width:100%;padding:14px var(--space-lg);margin-bottom:var(--space-md);background:#fff;color:#333;border:1px solid #ddd;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--space-md);transition:all var(--transition-normal);box-shadow:0 1px 4px #0000000f}.btn-google:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a;border-color:#bbb}.login-divider{display:flex;align-items:center;margin:var(--space-lg) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#00000014}.login-divider span{padding:0 var(--space-md);color:var(--color-text-muted);font-size:.85rem}.dev-login-form{display:flex;flex-direction:column;gap:var(--space-md)}.dev-login-form .input{padding:14px var(--space-md);font-size:1rem;border-radius:var(--radius-md);text-align:center;background:#faf8f4}.dev-login-form .btn-primary{padding:14px;font-size:1.1rem;border-radius:var(--radius-lg)}.login-features{display:flex;justify-content:center;gap:var(--space-xl);margin-top:var(--space-xl)}.feature{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--color-text-secondary);font-size:.82rem;font-weight:500}.feature-icon{font-size:1.4rem}.avatar-picker{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.avatar-label{font-size:.85rem;color:var(--color-text-secondary);font-weight:500}.avatar-options{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.avatar-option{font-size:1.8rem;padding:8px;border-radius:50%;border:2px solid transparent;background:#fff;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #0000000d}.avatar-option:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.avatar-option.selected{border-color:#2e7d4f;background:#f0fdf4;transform:scale(1.1);box-shadow:0 4px 12px #2e7d4f33}.auth-tabs-container{background:#f3f4f6;padding:6px;border-radius:12px;margin-bottom:var(--space-xl)}.auth-tabs{display:flex;gap:4px}.auth-tab{flex:1;padding:8px 12px;border:none;background:transparent;border-radius:8px;font-size:.9rem;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.auth-tab:hover{color:var(--color-text-primary)}.auth-tab.active{background:#fff;color:#2e7d4f;box-shadow:0 2px 8px #0000000d}.auth-form{display:flex;flex-direction:column;gap:var(--space-md);text-align:left}.form-group{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:.85rem;font-weight:600;color:var(--color-text-secondary)}.auth-input{width:100%;padding:12px 16px;border-radius:8px;border:1px solid #e5e7eb;background:#f9fafb;font-size:1rem;transition:all .2s}.auth-input:focus{outline:none;border-color:#2e7d4f;background:#fff;box-shadow:0 0 0 3px #2e7d4f1a}.auth-submit-btn{margin-top:var(--space-sm);padding:14px}.auth-error-banner{background:#fef2f2;color:#ef4444;padding:10px;border-radius:8px;font-size:.85rem;margin-bottom:var(--space-md);border:1px solid #fca5a5}.lobby-page{min-height:100vh;display:flex;flex-direction:column}.lobby-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:#fff;border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 1px 4px #0000000a}.nav-user{display:flex;align-items:center;gap:var(--space-md);color:var(--color-text-secondary)}.lobby-content{flex:1;display:flex;flex-direction:column;justify-content:center;padding-top:var(--space-xl);padding-bottom:var(--space-2xl);width:100%}.lobby-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg);margin-bottom:var(--space-2xl)}.action-card{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.action-card h3{font-size:1.3rem}.action-card p{color:var(--color-text-secondary);font-size:.9rem}.join-form{display:flex;gap:var(--space-sm);width:100%}.join-form .input{text-align:center;font-size:1.2rem;letter-spacing:3px;font-weight:700}.error-banner{background:#c0392b14;color:var(--color-danger);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg);text-align:center;border:1px solid rgba(192,57,43,.15)}.active-lobbies h3{margin-bottom:var(--space-md)}.lobbies-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.lobby-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md)}.lobby-item-info{display:flex;flex-direction:column;gap:var(--space-xs)}.lobby-host{font-weight:600}.lobby-players-count{font-size:.85rem;color:var(--color-text-secondary)}.lobby-room{max-width:500px;margin:var(--space-2xl) auto;padding:var(--space-lg)}.room-header{text-align:center;margin-bottom:var(--space-xl)}.room-code-display{display:flex;flex-direction:column;align-items:center;margin-top:var(--space-md);padding:var(--space-md);background:#fff;border-radius:var(--radius-md);border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 4px #0000000a}.room-code-label{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px}.room-code-value{font-size:2rem;font-weight:800;font-family:var(--font-display);letter-spacing:6px;color:var(--color-accent-primary)}.invite-section{margin-top:var(--space-md)}.invite-label{font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.invite-link-row{display:flex;gap:var(--space-sm)}.invite-input{font-size:.8rem!important;color:var(--color-accent-primary)!important;cursor:text}.btn-success{background:var(--color-success)!important;color:#fff}.room-players{margin-bottom:var(--space-xl)}.room-players h3{margin-bottom:var(--space-md)}.player-slot{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:#fff;border-radius:var(--radius-md);margin-bottom:var(--space-sm);border:1px solid rgba(0,0,0,.06);transition:all var(--transition-normal);box-shadow:0 1px 3px #0000000a}.player-slot.ready{border-color:var(--color-success);background:#2e7d4f0a}.player-slot.empty{justify-content:center;color:var(--color-text-muted);border-style:dashed;background:#faf8f4;box-shadow:none}.player-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-bg-elevated)}.emoji-avatar{display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#444}.player-name{flex:1;font-weight:600}.status-ready{color:var(--color-success)}.status-waiting{color:var(--color-text-muted)}.room-actions{text-align:center}.room-actions .btn-lg{width:100%;margin-bottom:var(--space-lg)}.ai-actions{margin-top:var(--space-md)}.ai-label{color:var(--color-text-muted);font-size:.85rem;margin-bottom:var(--space-sm)}.ai-buttons{display:flex;gap:var(--space-sm);justify-content:center}.game-page{height:100vh;display:flex;flex-direction:column;background:#fdfdf9;background-image:radial-gradient(ellipse at top left,rgba(235,230,222,.5) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(200,220,205,.4) 0%,transparent 50%);color:#1a1a1a;overflow:hidden}.game-header{display:flex;align-items:center;gap:12px;padding:8px 20px;background:#fff9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.05);flex-shrink:0;box-shadow:0 2px 10px #00000005}.game-info{display:flex;align-items:center;gap:14px;flex:1}.room-badge{padding:4px 14px;background:#0000000d;border-radius:20px;font-size:.8rem;color:#4a5568;font-weight:500}.turn-indicator{font-weight:600;color:#4a5568;font-size:.95rem}.turn-indicator.my-turn{color:#38a169;animation:pulse-glow-light 2s infinite}@keyframes pulse-glow-light{0%,to{opacity:1;text-shadow:0 0 5px rgba(56,161,105,.4)}50%{opacity:.7;text-shadow:none}}.game-message{padding:4px 14px;background:#3182ce1a;border-radius:20px;font-size:.85rem;color:#2b6cb0;font-weight:500}.game-layout{display:flex;flex:1;overflow:hidden;min-height:0}.game-sidebar,.chat-sidebar{width:220px;padding:16px;background:#fff6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex-shrink:0}.chat-sidebar{border-right:none;border-left:1px solid rgba(0,0,0,.05)}.game-sidebar h3,.chat-sidebar h3{font-size:.95rem;color:#2d3748;font-weight:700;margin-bottom:4px}.game-player{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;font-size:.9rem;color:#4a5568;background:#ffffff80;box-shadow:0 2px 5px #00000005;border:1px solid rgba(0,0,0,.03)}.game-player.active-player{background:#fff;border:1px solid rgba(74,222,128,.4);box-shadow:0 4px 10px #0000000a,0 0 0 1px #4ade8033}.chip-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:inset 0 2px 4px #0003,0 1px 2px #0000001a}.game-player-name{flex:1;font-weight:600;color:#1a202c}.game-player-cards{font-size:.75rem;color:#a0aec0;font-weight:600}.suggestion-item{padding:8px;background:#fff;border-radius:8px;margin-top:6px;font-size:.8rem;cursor:pointer;color:#2d3748;box-shadow:0 2px 4px #00000005;border:1px solid rgba(0,0,0,.05);transition:all .2s ease}.suggestion-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000000d;border-color:#0000001a}.suggestion-reason{display:block;color:#718096;font-size:.7rem;margin-top:2px}.game-stats{margin-top:auto;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000008;border:1px solid rgba(0,0,0,.05)}.stat{display:flex;justify-content:space-between;padding:4px 0;color:#2d3748}.stat-label{color:#718096;font-size:.8rem;font-weight:500}.stat-value{font-weight:700;font-size:.85rem;color:#1a202c}.board-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden;min-height:0}.board-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:4px;padding:12px;background:#faf8f599;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;box-shadow:0 24px 48px #0000000d,0 1px 3px #00000005,inset 0 1px #fffc,inset 0 0 20px #ffffff80;border:1px solid rgba(255,255,255,.7);width:100%;max-width:calc((100dvh - 160px) * (10 / 14));aspect-ratio:10 / 14;height:auto;margin:0 auto}.board-cell{position:relative;border-radius:6px;overflow:hidden;cursor:default;background:#fdfcfa;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;box-shadow:0 4px 10px #00000008,0 1px 2px #00000005}.board-cell.valid-target{cursor:pointer;box-shadow:0 0 0 3px #48bb78,0 8px 16px #48bb784d;transform:scale(1.1) translateY(-2px);z-index:2}.board-cell.valid-target:hover{transform:scale(1.15) translateY(-4px);box-shadow:0 0 0 4px #38a169,0 12px 24px #38a16966}.board-cell.remove-target{box-shadow:0 0 0 3px #f56565,0 8px 16px #f565654d!important}.board-cell.remove-target:hover{box-shadow:0 0 0 4px #e53e3e,0 12px 24px #e53e3e66!important}.card-face{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:space-between;background:#fdfcfa;padding:5% 6%;font-family:Outfit,Inter,sans-serif;-webkit-user-select:none;user-select:none;box-shadow:inset 0 0 12px #00000003}.card-face.card-red{color:#d1565a}.card-face.card-black{color:#3f4756}.card-face-board .cf-rank{align-self:flex-start;font-size:clamp(.6rem,2cqw,.9rem);font-weight:800;line-height:1;letter-spacing:-.5px}.card-face-board .cf-suit{font-size:clamp(1rem,4cqw,1.8rem);line-height:1;display:flex;justify-content:center;width:100%;filter:drop-shadow(0 2px 2px rgba(0,0,0,.05))}.card-face-board .cf-rank-bot{align-self:flex-end;transform:rotate(180deg)}.card-power{background:#f7fafc;box-shadow:inset 0 0 12px #00000008}.cf-label{font-size:clamp(.4rem,1.4cqw,.65rem);font-weight:800;letter-spacing:.5px;background:#1a202c;color:#fff;padding:3px 6px;border-radius:4px;margin-top:-4px;z-index:1;text-align:center;box-shadow:0 2px 4px #0000001a}.card-power.card-red .cf-label{background:#e53e3e}.card-face-hand .cf-rank{align-self:flex-start;font-size:.85rem;font-weight:800;line-height:1}.card-face-hand .cf-suit{font-size:1.5rem;line-height:1;filter:drop-shadow(0 2px 3px rgba(0,0,0,.1))}.card-face-hand .cf-rank-bot{align-self:flex-end;transform:rotate(180deg);font-size:.85rem;font-weight:800;line-height:1}.free-cell{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fffcf2,#f6e6cc);position:relative;border-radius:6px}.free-cell:after{content:"⭐";font-size:clamp(1.2rem,4.5cqw,2.2rem);filter:drop-shadow(0 2px 4px rgba(212,175,55,.3));opacity:.8}.chip-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72%;height:72%;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.4) 0%,transparent 60%),repeating-conic-gradient(from 0deg,rgba(0,0,0,.08) 0deg 10deg,transparent 10deg 20deg),var(--chip-color);box-shadow:0 8px 16px #00000040,0 3px 6px #00000026,inset 0 4px 6px #ffffff4d,inset 0 -4px 8px #0006,0 0 0 1px #0003;display:flex;align-items:center;justify-content:center}.chip-inner{width:60%;height:60%;border-radius:50%;background:var(--chip-color);border:2px solid rgba(255,255,255,.15);box-shadow:inset 0 4px 6px #0003,0 2px 4px #ffffff40;position:relative}.chip-inner:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60%;height:60%;border-radius:50%;border:1px dashed rgba(255,255,255,.4);opacity:.7}.chip-overlay.chip-animate{animation:chip-drop .6s cubic-bezier(.34,1.56,.64,1)}@keyframes chip-drop{0%{transform:translate(-50%,-150%) scale(0) rotate(-180deg);opacity:0;box-shadow:0 20px 30px #0006}50%{transform:translate(-50%,-50%) scale(1.1) rotate(0);opacity:1;box-shadow:0 10px 20px #0000004d}to{transform:translate(-50%,-50%) scale(1) rotate(0)}}.board-cell.chip-placed{animation:cell-pulse 1.5s ease-out}@keyframes cell-pulse{0%{box-shadow:0 0 #4ade8099}50%{box-shadow:0 0 16px 8px #4ade8033}to{box-shadow:0 2px 5px #0000000f,0 1px 1px #0000000a}}.board-cell.in-sequence{box-shadow:0 0 0 3px #ecc94b,0 4px 12px #ecc94b66;transform:scale(1.02);z-index:1}.board-cell.in-sequence .chip-overlay{animation:sequence-glow 2s infinite alternate}@keyframes sequence-glow{0%{filter:brightness(1)}to{filter:brightness(1.2) drop-shadow(0 0 6px rgba(255,255,255,.5))}}.board-cell.new-sequence{animation:seq-celebrate 3s ease-out;z-index:3}@keyframes seq-celebrate{0%{box-shadow:0 0 #ecc94bcc;transform:scale(1)}15%{box-shadow:0 0 24px 12px #ecc94b99;transform:scale(1.1)}30%{transform:scale(1.02)}60%{box-shadow:0 0 12px 6px #ecc94b4d}to{box-shadow:0 0 0 3px #ecc94b,0 4px 12px #ecc94b66}}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.chat-msg{font-size:.8rem;padding:6px 10px;background:#fff;border-radius:8px;word-break:break-word;color:#2d3748;box-shadow:0 1px 3px #00000005;border:1px solid rgba(0,0,0,.03)}.chat-form{display:flex;gap:6px;margin-top:4px}.chat-form .input{font-size:.85rem;padding:8px 12px;border-color:#0000001a;background:#fff}.hand-container{padding:12px 24px;background:#fff9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.05);display:flex;align-items:center;gap:16px;flex-shrink:0;box-shadow:0 -4px 12px #00000005}.hand-label{color:#4a5568;font-size:.9rem;font-weight:700;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.hand-cards{display:flex;gap:10px;overflow-x:auto;padding:8px 4px;scrollbar-width:none}.hand-cards::-webkit-scrollbar{display:none}.hand-card{width:65px;height:94px;border:1px solid rgba(0,0,0,.05);border-radius:6px;background:#fff;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;box-shadow:0 4px 8px #0000000f,0 1px 2px #0000000a;padding:0;overflow:hidden}.hand-card.playable:hover{transform:translateY(-12px);border-color:#48bb7880;box-shadow:0 12px 24px #0000001a,0 0 0 2px #48bb7833}.hand-card.selected{transform:translateY(-16px);border-color:#ecc94b;box-shadow:0 16px 32px #ecc94b33,0 0 0 3px #ecc94b66}.hand-card:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(1)}.game-over-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffd9;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.game-over-card{text-align:center;padding:48px;max-width:450px;background:#fff;box-shadow:0 20px 40px #0000001a;border:1px solid rgba(0,0,0,.05);border-radius:16px}.game-over-card h2{font-size:2.8rem;margin-bottom:16px;color:#1a202c}.winner-text{font-size:1.4rem;color:#d69e2e;margin-bottom:28px;font-weight:700}@media (max-width: 1024px){.game-sidebar,.chat-sidebar{width:180px;padding:12px}}@media (max-width: 768px){.game-page{height:100dvh}.game-header{padding:6px 12px;gap:8px}.game-header .btn{padding:4px 8px;font-size:.8rem}.room-badge{font-size:.75rem}.game-message,.game-sidebar,.chat-sidebar{display:none}.board-grid{height:calc(100dvh - 120px);padding:6px;gap:2px;border-radius:8px}.hand-container{padding:6px 12px;gap:8px}.hand-label{font-size:.75rem}.hand-cards{gap:6px}.hand-card{width:48px;height:70px;border-radius:4px}.hand-card.playable:hover{transform:translateY(-6px)}.hand-card.selected{transform:translateY(-10px)}.card-face-hand .cf-rank,.card-face-hand .cf-rank-bot{font-size:.65rem}.card-face-hand .cf-suit{font-size:1.1rem}}:root{--color-bg-primary: #f5f0e8;--color-bg-secondary: #ebe5d9;--color-bg-card: #ffffff;--color-bg-elevated: #f9f5ee;--color-bg-glass: rgba(255, 255, 255, .7);--color-accent-primary: #2e7d4f;--color-accent-secondary: #3a9d63;--color-accent-warm: #d4903a;--color-accent-glow: rgba(46, 125, 79, .2);--color-success: #2e7d4f;--color-warning: #d4903a;--color-danger: #c0392b;--color-text-primary: #2c2c2c;--color-text-secondary: #5c5c5c;--color-text-muted: #8a8a8a;--color-chip-blue: #3b82f6;--color-chip-green: #16a34a;--color-chip-red: #dc2626;--font-display: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--shadow-glow: 0 0 16px var(--color-accent-glow);--shadow-card: 0 2px 12px rgba(0, 0, 0, .08);--shadow-soft: 0 4px 16px rgba(0, 0, 0, .06);--transition-fast: .15s ease;--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at 30% 20%,rgba(46,125,79,.05) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(212,144,58,.04) 0%,transparent 60%);pointer-events:none;z-index:0}#root{position:relative;z-index:1}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--color-text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn-primary{background:linear-gradient(135deg,#2e7d4f,#3a9d63);color:#fff;box-shadow:0 4px 14px #2e7d4f4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2e7d4f66}.btn-secondary{background:#fff;color:var(--color-text-primary);border:1px solid #d4d0c8}.btn-secondary:hover{background:#f5f0e8;border-color:var(--color-accent-primary)}.btn-danger{background:linear-gradient(135deg,#c0392b,#e74c3c);color:#fff}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:1.1rem;border-radius:var(--radius-lg)}.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);transition:all var(--transition-normal)}.card:hover{border-color:#2e7d4f33;box-shadow:var(--shadow-card),0 0 12px #2e7d4f14}.glass{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg)}.input{width:100%;padding:var(--space-sm) var(--space-md);background:#faf8f4;border:1px solid #d4d0c8;border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:1rem;transition:all var(--transition-fast);outline:none}.input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow);background:#fff}.input::placeholder{color:var(--color-text-muted)}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow-pulse{0%,to{box-shadow:0 0 5px var(--color-accent-glow)}50%{box-shadow:0 0 20px var(--color-accent-glow),0 0 30px var(--color-accent-glow)}}.animate-fadeIn{animation:fadeIn .6s cubic-bezier(.4,0,.2,1) forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#2e7d4f66}.chip-dot{width:12px;height:12px;border-radius:50%;display:inline-block}
