/* ===== BASE ===== */
:root {
  --bg:        #09090e;
  --surface:   #111118;
  --surface-2: #18181f;
  --surface-3: #21212d;
  --border:    rgba(255,255,255,0.07);
  --border-md: rgba(255,255,255,0.13);
  --border-hi: rgba(255,255,255,0.22);
  --text:      #e4e4f0;
  --text-dim:  #7c7c9a;
  --text-muted:#3e3e5a;

  --activity: #a598ff; --activity-dim: rgba(165,152,255,0.11); --activity-glow: rgba(165,152,255,0.25);
  --food:     #f09348; --food-dim:     rgba(240,147,72,0.11);  --food-glow:     rgba(240,147,72,0.25);
  --drink:    #3dd6a3; --drink-dim:    rgba(61,214,163,0.11);  --drink-glow:    rgba(61,214,163,0.25);

  --green: #3dd6a3; --green-dim: rgba(61,214,163,0.12);
  --red:   #ff4466; --red-dim:   rgba(255,68,102,0.12);
  --blue:  #60a5fa; --blue-dim:  rgba(96,165,250,0.12);

  --radius-xs: 6px;
  --radius-sm: 10px;
  --radius:    14px;
  --radius-lg: 20px;

  --ease: cubic-bezier(0.22,1,0.36,1);
  --t: 0.18s;
  --nav-h: 58px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
input,button,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:3px}
a{color:inherit;text-decoration:none}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav-h);background:rgba(9,9,14,0.8);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:20px}
.nav-brand{font-size:17px;font-weight:700;letter-spacing:-0.6px;background:linear-gradient(135deg,#a598ff,#5ee8bc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;user-select:none;white-space:nowrap}
.nav-links{display:flex;gap:2px;list-style:none}
.nav-link{padding:5px 13px;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-dim);font-size:13.5px;font-weight:500;cursor:pointer;transition:color var(--t),background var(--t)}
.nav-link:hover{color:var(--text);background:var(--surface-2)}
.nav-link.active{color:var(--text);background:var(--surface-2)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-user{font-size:12.5px;color:var(--text-muted);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn-signout{padding:5px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:none;color:var(--text-muted);font-size:12.5px;cursor:pointer;transition:color var(--t),border-color var(--t)}
.btn-signout:hover{color:var(--red);border-color:var(--red)}

/* ===== LAYOUT ===== */
main{margin-top:var(--nav-h);min-height:calc(100vh - var(--nav-h))}
.view{padding:36px 28px 80px;max-width:1100px;margin:0 auto;animation:fadeUp .25s var(--ease) both}
.view-wide{max-width:1260px}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ===== LOADING ===== */
.loading-screen{display:flex;align-items:center;justify-content:center;min-height:60vh}
.loading{display:flex;align-items:center;justify-content:center;padding:80px}
.spinner{width:28px;height:28px;border:2.5px solid var(--surface-3);border-top-color:var(--activity);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== PAGE HEADER ===== */
.page-header{margin-bottom:28px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-header-left h1{font-size:26px;font-weight:700;letter-spacing:-.8px;margin-bottom:4px}
.page-header-left p{font-size:14px;color:var(--text-dim)}
.page-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);border:none;font-size:13.5px;font-weight:600;cursor:pointer;transition:opacity var(--t),transform var(--t),box-shadow var(--t);white-space:nowrap;letter-spacing:.1px}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn:active{transform:translateY(0);opacity:1}
.btn-primary{background:linear-gradient(135deg,#8b7ff5,#6352d6);color:#fff;box-shadow:0 4px 16px rgba(139,127,245,.3)}
.btn-primary:hover{box-shadow:0 8px 24px rgba(139,127,245,.45)}
.btn-ghost{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--text);border-color:var(--border-md)}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,68,102,.25)}
.btn-danger:hover{background:rgba(255,68,102,.2)}
.btn-success{background:var(--green-dim);color:var(--green);border:1px solid rgba(61,214,163,.25)}
.btn-sm{padding:6px 12px;font-size:12.5px}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center;background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius-sm)}
.btn-icon:hover{color:var(--text);border-color:var(--border-md)}
.btn[disabled]{opacity:.4;cursor:not-allowed;transform:none !important}

/* ===== FORM ELEMENTS ===== */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}
.input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 13px;color:var(--text);font-size:14px;outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%}
.input:focus{border-color:rgba(165,152,255,.5);box-shadow:0 0 0 3px rgba(165,152,255,.1)}
.input::placeholder{color:var(--text-muted)}
textarea.input{resize:vertical;min-height:72px}

/* ===== CARDS ===== */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.card-sm{padding:14px 16px}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;letter-spacing:.2px;white-space:nowrap}
.badge-published{background:var(--green-dim);color:var(--green);border:1px solid rgba(61,214,163,.25)}
.badge-private{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}
.badge-owner{background:var(--activity-dim);color:var(--activity);border:1px solid rgba(165,152,255,.25)}
.badge-contributor{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}
.badge-no-dupes{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(96,165,250,.25)}

/* ===== TOAST ===== */
#toast-root{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:var(--surface-2);border:1px solid var(--border-md);border-radius:var(--radius-sm);padding:10px 16px;font-size:13.5px;font-weight:500;color:var(--text);box-shadow:0 8px 32px rgba(0,0,0,.5);transform:translateX(110%);transition:transform .3s var(--ease);pointer-events:auto;max-width:320px}
.toast.show{transform:translateX(0)}
.toast-success{border-left:3px solid var(--green);color:var(--green)}
.toast-error{border-left:3px solid var(--red);color:var(--red)}
.toast-info{border-left:3px solid var(--blue);color:var(--blue)}

/* ===== MODAL ===== */
#modal-root{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center}
#modal-root.active{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px)}
.modal{position:relative;z-index:1;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:480px;margin:20px;animation:modalIn .25s var(--ease) both}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-title{font-size:17px;font-weight:700;letter-spacing:-.4px;margin-bottom:20px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}
.modal-close{position:absolute;top:16px;right:16px;width:28px;height:28px;border:none;background:none;color:var(--text-muted);font-size:18px;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color var(--t),background var(--t)}
.modal-close:hover{color:var(--text);background:var(--surface-2)}

/* ===== AUTH VIEW ===== */
.auth-view{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--nav-h));padding:24px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;width:100%;max-width:420px}
.auth-logo{font-size:24px;font-weight:700;letter-spacing:-.8px;background:linear-gradient(135deg,#a598ff,#5ee8bc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.auth-subtitle{font-size:14px;color:var(--text-dim);margin-bottom:28px}
.auth-tabs{display:flex;gap:2px;background:var(--surface-2);border-radius:var(--radius-sm);padding:3px;margin-bottom:24px}
.auth-tab{flex:1;padding:7px;border:none;background:none;color:var(--text-dim);font-size:13.5px;font-weight:500;cursor:pointer;border-radius:8px;transition:all var(--t)}
.auth-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-error{background:var(--red-dim);border:1px solid rgba(255,68,102,.25);border-radius:var(--radius-sm);padding:10px 13px;font-size:13px;color:var(--red)}
.auth-switch{text-align:center;font-size:13px;color:var(--text-muted);margin-top:16px}
.auth-switch button{background:none;border:none;color:var(--activity);font-size:13px;font-weight:500;cursor:pointer}
.auth-switch button:hover{text-decoration:underline}

/* ===== POOL CARDS GRID ===== */
.pools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.pool-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:14px;cursor:pointer;transition:border-color var(--t),transform var(--t),box-shadow var(--t)}
.pool-card:hover{border-color:var(--border-md);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.pool-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.pool-card-name{font-size:15.5px;font-weight:600;letter-spacing:-.3px;color:var(--text)}
.pool-card-desc{font-size:13px;color:var(--text-dim);margin-top:4px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.45}
.pool-card-badges{display:flex;gap:6px;flex-wrap:wrap}
.pool-card-counts{display:flex;gap:7px;flex-wrap:wrap}
.cat-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;color:var(--cat-color);background:var(--cat-color-dim)}
.pool-card-footer{display:flex;align-items:center;justify-content:space-between}
.pool-card-meta{font-size:11.5px;color:var(--text-muted)}
.empty-pools{text-align:center;padding:80px 24px;color:var(--text-muted)}
.empty-pools .empty-icon{font-size:48px;margin-bottom:16px;opacity:.35}
.empty-pools p{font-size:14px;color:var(--text-dim);margin-bottom:6px}
.empty-pools .empty-sub{font-size:13px}

/* ===== POOL DETAIL ===== */
.pool-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 28px;margin-bottom:24px}
.pool-header-top{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}
.pool-header-info{flex:1;min-width:0}
.pool-title{font-size:24px;font-weight:700;letter-spacing:-.7px;margin-bottom:6px}
.pool-desc{font-size:14px;color:var(--text-dim);margin-bottom:12px}
.pool-header-badges{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.pool-stat{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:3px}
.pool-header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;flex-shrink:0}

/* Pool tabs */
.pool-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border)}
.pool-tab{padding:9px 18px;border:none;background:none;color:var(--text-dim);font-size:13.5px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--t),border-color var(--t),background var(--t);border-radius:var(--radius-sm) var(--radius-sm) 0 0}
.pool-tab:hover{color:var(--text);background:var(--surface-2)}
.pool-tab.active{color:var(--text);border-bottom-color:var(--activity)}

/* ===== SUGGEST TAB ===== */
.category-tabs{display:flex;gap:6px;margin-bottom:20px;border-bottom:1px solid var(--border)}
.tab-btn{display:flex;align-items:center;gap:7px;padding:9px 16px;border:none;background:none;color:var(--text-dim);font-size:13.5px;font-weight:500;cursor:pointer;border-radius:var(--radius-sm) var(--radius-sm) 0 0;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--t),background var(--t),border-color var(--t);white-space:nowrap}
.tab-btn:hover{color:var(--text);background:var(--surface-2)}
.tab-btn.active{color:var(--text);border-bottom-color:var(--cat-color);background:var(--surface)}
.tab-icon{font-size:15px;line-height:1}
.tab-count{background:var(--surface-3);color:var(--text-muted);font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px;transition:background var(--t),color var(--t)}
.tab-btn.active .tab-count{background:var(--cat-color-dim);color:var(--cat-color)}

.add-form{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:13px 16px;margin-bottom:22px;transition:border-color var(--t)}
.add-form:focus-within{border-color:var(--border-md)}
.add-form-icon{font-size:18px;flex-shrink:0;line-height:1}
.add-form input{flex:1;background:none;border:none;color:var(--text);font-size:14.5px;outline:none}
.add-form input::placeholder{color:var(--text-muted)}
.btn-add{padding:8px 18px;border-radius:var(--radius-sm);border:none;background:var(--cat-color,#8b7ff5);color:#fff;font-size:13.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity var(--t),transform var(--t),box-shadow var(--t)}
.btn-add:hover{opacity:.86;transform:translateY(-1px)}
.btn-add:active{transform:translateY(0)}

.suggestions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.suggestions-title{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text-dim)}
.suggestions-title .dot{width:7px;height:7px;border-radius:50%;background:var(--cat-color);flex-shrink:0}
.suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:9px}

.suggestion-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;display:flex;align-items:flex-start;gap:10px;transition:border-color var(--t),background var(--t);animation:cardIn .2s var(--ease) both}
@keyframes cardIn{from{opacity:0;transform:scale(.97) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}
.suggestion-card:hover{border-color:color-mix(in srgb,var(--cat-color) 28%,transparent);background:var(--surface-2)}
.suggestion-content{flex:1;min-width:0}
.suggestion-text{font-size:13.5px;color:var(--text);word-break:break-word;line-height:1.4}
.suggestion-meta{display:flex;align-items:center;gap:5px;margin-top:5px;flex-wrap:wrap}
.suggestion-user,.suggestion-date{font-size:11px;color:var(--text-muted)}
.suggestion-dot{width:2px;height:2px;border-radius:50%;background:var(--text-muted);flex-shrink:0}
.suggestion-actions{display:flex;gap:4px;flex-shrink:0}
.delete-btn{width:22px;height:22px;border:none;background:none;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:color var(--t),background var(--t)}
.delete-btn:hover{color:var(--red);background:var(--red-dim)}
.copy-btn{width:22px;height:22px;border:none;background:none;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;transition:color var(--t),background var(--t)}
.copy-btn:hover{color:var(--activity);background:var(--activity-dim)}

.empty-state{text-align:center;padding:52px 24px;color:var(--text-muted)}
.empty-icon{font-size:40px;margin-bottom:12px;opacity:.4}
.empty-primary{font-size:14px;font-weight:500;color:var(--text-dim);margin-bottom:4px}
.empty-sub{font-size:13px}

.readonly-notice{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--text-dim);margin-bottom:20px;display:flex;align-items:center;gap:8px}

/* ===== GENERATE TAB ===== */
.generate-controls{display:flex;flex-wrap:wrap;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:28px}
.control-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin-bottom:7px}
.count-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;color:var(--text);font-size:20px;font-weight:700;width:90px;outline:none;transition:border-color var(--t);text-align:center;-moz-appearance:textfield}
.count-input::-webkit-inner-spin-button,.count-input::-webkit-outer-spin-button{-webkit-appearance:none}
.count-input:focus{border-color:rgba(165,152,255,.5)}
.control-divider{width:1px;height:40px;background:var(--border);flex-shrink:0}
.gen-ctrl{display:flex;flex-direction:column;gap:0}
.toggle-wrapper{display:flex;align-items:center;gap:10px}
.toggle{position:relative;cursor:pointer;width:42px;height:24px;flex-shrink:0}
.toggle input{position:absolute;opacity:0;width:0;height:0}
.toggle-track{position:absolute;inset:0;border-radius:12px;background:var(--surface-3);border:1px solid var(--border);transition:background .25s,border-color .25s}
.toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:transform .25s,background .25s}
.toggle input:checked+.toggle-track{background:rgba(139,127,245,.25);border-color:rgba(139,127,245,.5)}
.toggle input:checked+.toggle-track .toggle-thumb{transform:translateX(18px);background:#a598ff}
.toggle-label{font-size:13px;color:var(--text-dim);font-weight:500;max-width:220px;line-height:1.3}
.btn-generate{margin-left:auto;display:flex;align-items:center;gap:8px;padding:11px 24px;border-radius:var(--radius-sm);border:none;background:linear-gradient(135deg,#8b7ff5,#6352d6);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(139,127,245,.35)}
.btn-generate:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(139,127,245,.5)}
.btn-generate:active{transform:translateY(0)}
.btn-reshuffle{display:flex;align-items:center;gap:7px;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-md);background:var(--surface-2);color:var(--text-dim);font-size:13px;font-weight:500;cursor:pointer;transition:color var(--t),background var(--t)}
.btn-reshuffle:hover{color:var(--text);background:var(--surface-3)}

.chance-row{display:flex;flex-direction:column;gap:0;min-width:160px}
.chance-slider{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:3px;background:var(--surface-3);outline:none;transition:background var(--t)}
.chance-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#a598ff;cursor:pointer;transition:transform .15s,box-shadow .15s}
.chance-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 5px rgba(165,152,255,.2)}
.chance-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#a598ff;cursor:pointer;border:none}
.chance-display{font-size:14px;font-weight:700;color:var(--text);min-width:38px;text-align:right}

.generate-placeholder{text-align:center;padding:80px 24px;color:var(--text-muted)}
.placeholder-glyph{font-size:48px;margin-bottom:18px;background:linear-gradient(135deg,#8b7ff5,#3dd6a3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.4}
.placeholder-text{font-size:15px;font-weight:500;color:var(--text-dim);margin-bottom:5px}
.placeholder-sub{font-size:13px}
.warning-banner{background:rgba(240,147,72,.08);border:1px solid rgba(240,147,72,.25);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--food);margin-bottom:16px}
.error-banner{background:var(--red-dim);border:1px solid rgba(255,68,102,.25);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--red);margin-bottom:16px}
.results-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.results-count{font-size:13px;font-weight:600;color:var(--text-dim)}
.results-mode{font-size:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:2px 9px;color:var(--text-muted)}
.combo-grid-header{display:grid;gap:10px;margin-bottom:8px;padding:0 2px}
.combo-col-header{display:flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--cat-color);padding-left:14px}
.combo-grid{display:flex;flex-direction:column;gap:9px}
.combo-row{display:grid;gap:10px;animation:rowIn .3s var(--ease) both}
@keyframes rowIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}
.combo-row-number{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--surface-2);border:1px solid var(--border);border-radius:50%;font-size:11px;font-weight:700;color:var(--text-muted);flex-shrink:0;align-self:center;user-select:none}
.combo-cell{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--cat-color);border-radius:var(--radius-sm);padding:13px 15px;transition:border-color var(--t),background var(--t),transform var(--t),box-shadow var(--t);position:relative;overflow:hidden}
.combo-cell::after{content:'';position:absolute;inset:0;background:var(--cat-color-dim,rgba(139,127,245,.08));opacity:0;transition:opacity var(--t);pointer-events:none}
.combo-cell:hover{border-color:color-mix(in srgb,var(--cat-color) 50%,transparent);background:var(--surface-2);transform:translateY(-2px);box-shadow:0 4px 18px var(--cat-color-glow,rgba(139,127,245,.2))}
.combo-cell:hover::after{opacity:1}
.combo-cell-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--cat-color);margin-bottom:5px}
.combo-cell-text{font-size:14.5px;font-weight:500;color:var(--text);line-height:1.35}
.combo-cell-user{font-size:11px;color:var(--text-muted);margin-top:5px}
.combo-modifier-pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px;background:rgba(244,114,182,0.12);color:var(--mod-color,#f472b6);border:1px solid rgba(244,114,182,0.28);margin-top:5px;margin-bottom:3px;letter-spacing:.1px}

/* ===== MEMBERS TAB ===== */
.invite-section{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:24px}
.invite-section h3{font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}
.invite-link-row{display:flex;align-items:center;gap:8px}
.invite-link-box{flex:1;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 13px;font-size:12.5px;color:var(--text-dim);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.members-list{display:flex;flex-direction:column;gap:8px}
.member-row{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--t)}
.member-row:hover{border-color:var(--border-md)}
.member-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;background:var(--surface-2);color:var(--activity);border:1px solid var(--border);flex-shrink:0;text-transform:uppercase}
.member-info{flex:1;min-width:0}
.member-name{font-size:14px;font-weight:500;color:var(--text)}
.member-joined{font-size:11.5px;color:var(--text-muted);margin-top:2px}
.member-actions{display:flex;align-items:center;gap:6px}

/* ===== BROWSE VIEW ===== */
.browse-search-row{display:flex;gap:10px;margin-bottom:24px}
.browse-search-row .input{max-width:380px}
.browse-stats{font-size:13px;color:var(--text-muted);margin-bottom:18px}
.browse-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:14px;transition:border-color var(--t),transform var(--t),box-shadow var(--t)}
.browse-card:hover{border-color:var(--border-md);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.browse-card-title{font-size:15.5px;font-weight:600;letter-spacing:-.3px}
.browse-card-desc{font-size:13px;color:var(--text-dim);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.browse-card-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.browse-meta-item{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.browse-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}
.browse-empty{text-align:center;padding:80px 24px;color:var(--text-muted)}

/* Pool explore view (within browse) */
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-dim);background:none;border:none;cursor:pointer;padding:0;margin-bottom:20px;transition:color var(--t)}
.back-link:hover{color:var(--text)}

/* ===== ADD TO POOL MODAL ===== */
.pool-options{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.pool-option{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--t),background var(--t);text-align:left;width:100%}
.pool-option:hover{border-color:var(--activity);background:var(--activity-dim)}
.pool-option-name{font-size:14px;font-weight:500;color:var(--text)}
.pool-option-meta{font-size:12px;color:var(--text-muted);margin-top:2px;display:flex;align-items:center;gap:6px}
.pool-option-nodup{font-size:10.5px;font-weight:600;color:var(--blue);background:var(--blue-dim);border:1px solid rgba(96,165,250,.2);border-radius:10px;padding:1px 6px}
.pool-option-arrow{font-size:18px;color:var(--activity);flex-shrink:0}
.pool-option-rejected{border-color:rgba(255,68,102,.3) !important;background:var(--red-dim) !important;cursor:default}
.pool-option-dup-err{color:var(--red);font-size:12px}
.no-pools-msg{font-size:14px;color:var(--text-dim);text-align:center;padding:20px 0}

/* ===== RESPONSIVE ===== */
@media(max-width:700px){
  .view{padding:20px 16px 60px}
  nav{padding:0 16px}
  .page-header{flex-direction:column}
  .control-divider,.toggle-label{display:none}
  .btn-generate{margin-left:0}
  .generate-controls{gap:14px}
  .pool-header-top{flex-direction:column}
  .pool-header-actions{width:100%}
  .invite-link-row{flex-wrap:wrap}
}
@media(max-width:500px){
  .suggestions-grid{grid-template-columns:1fr}
  .pools-grid{grid-template-columns:1fr}
}
