/* ══════════════════════════════════════════════
   RESET & BASE
══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #06060f;
  --surface:   #0c0c1e;
  --surface-2: #111128;
  --card-bg:   rgba(14, 14, 32, 0.7);
  --border:    rgba(255, 255, 255, 0.07);
  --border-hi: rgba(255, 255, 255, 0.14);
  --text:      #e0e2f0;
  --text-2:    #7e80a8;
  --text-3:    #3a3c5c;
  --purple:    #7c3aed;
  --cyan:      #06b6d4;
  --green:     #10b981;
  --red:       #ef4444;
  --yellow:    #f59e0b;
  --radius:    16px;
  --radius-sm: 10px;
  --ease:      cubic-bezier(0.4, 0, 0.2, 1);
  --dur:       180ms;
}

html { font-size: 16px; -webkit-tap-highlight-color: transparent; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--bg); color: var(--text);
  min-height: 100vh; overflow-x: hidden;
}

/* ── Background ── */
.bg-glow {
  position: fixed; border-radius: 50%; filter: blur(100px);
  pointer-events: none; z-index: 0;
  animation: driftGlow 20s ease-in-out infinite alternate;
}
.bg-glow-1 { width:600px;height:600px; background:radial-gradient(circle,rgba(124,58,237,.18) 0%,transparent 70%); top:-200px;left:-200px; animation-duration:18s; }
.bg-glow-2 { width:500px;height:500px; background:radial-gradient(circle,rgba(6,182,212,.12) 0%,transparent 70%); bottom:-150px;right:-150px; animation-duration:24s;animation-direction:alternate-reverse; }
.bg-glow-3 { width:400px;height:400px; background:radial-gradient(circle,rgba(236,72,153,.08) 0%,transparent 70%); top:50%;left:50%; transform:translate(-50%,-50%); animation-name:driftGlow3;animation-duration:30s; }
@keyframes driftGlow  { 0%{transform:translate(0,0)} 100%{transform:translate(40px,30px)} }
@keyframes driftGlow3 { 0%{transform:translate(-50%,-50%) scale(1)} 100%{transform:translate(-50%,-50%) scale(1.3)} }
.bg-grid {
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:44px 44px;
}

/* ── Navbar ── */
.navbar {
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;height:62px;
  background:rgba(6,6,15,.85);backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
}
.navbar-brand { display:flex;align-items:center;gap:10px; }
.brand-logo {
  font-size:26px;line-height:1;
  background:linear-gradient(135deg,var(--purple),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 12px rgba(124,58,237,.6));
}
.brand-name {
  font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;letter-spacing:4px;
  background:linear-gradient(90deg,#fff 20%,var(--cyan) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.navbar-actions { display:flex;gap:10px;align-items:center; }

/* ── Buttons ── */
.btn {
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 18px;border-radius:8px;
  font-size:14px;font-weight:600;cursor:pointer;
  border:none;outline:none;text-decoration:none;
  transition:all var(--dur) var(--ease);
  white-space:nowrap;user-select:none;
}
.btn:active { transform:scale(0.97); }
.btn-primary {
  background:linear-gradient(135deg,var(--purple) 0%,#5b21b6 50%,var(--cyan) 100%);
  background-size:200% 200%;background-position:0% 50%;
  color:#fff;
  transition:background-position .4s var(--ease),box-shadow var(--dur),transform var(--dur);
}
.btn-primary:hover { background-position:100% 50%;box-shadow:0 4px 24px rgba(124,58,237,.45);transform:translateY(-1px); }
.btn-ghost {
  background:rgba(255,255,255,.04);color:var(--text-2);
  border:1px solid var(--border);
}
.btn-ghost:hover { background:rgba(255,255,255,.08);color:var(--text);border-color:var(--border-hi); }

/* ── Admin button ── */
.admin-btn { position:relative; }
.admin-btn.is-admin {
  border-color:rgba(16,185,129,.4);
  color:#34d399;
  background:rgba(16,185,129,.08);
}
.admin-dot {
  position:absolute;top:6px;right:6px;
  width:7px;height:7px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 6px var(--green);
  animation:pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ── Admin dropdown menu ── */
.admin-menu {
  position:fixed;z-index:500;
  top:70px;right:28px;
  background:#0e0e22;
  border:1px solid rgba(124,58,237,.4);
  border-radius:12px;padding:6px;
  min-width:180px;
  box-shadow:0 12px 40px rgba(0,0,0,.6);
  opacity:0;pointer-events:none;transform:translateY(-8px) scale(.97);
  transition:opacity .18s,transform .18s;
}
.admin-menu.open { opacity:1;pointer-events:all;transform:translateY(0) scale(1); }

.admin-menu-item {
  display:flex;align-items:center;gap:10px;
  width:100%;padding:9px 12px;border-radius:8px;
  background:none;border:none;color:var(--text-2);
  font-size:13px;font-weight:500;cursor:pointer;
  transition:all var(--dur);text-align:left;
}
.admin-menu-item:hover { background:rgba(255,255,255,.06);color:var(--text); }
.admin-menu-logout { color:rgba(239,68,68,.8); }
.admin-menu-logout:hover { background:rgba(239,68,68,.1);color:var(--red); }
.admin-menu-divider { height:1px;background:var(--border);margin:4px 0; }

/* ── Sort select in navbar ── */
.sort-wrap {
  position:relative;display:inline-flex;align-items:center;
}
.sort-wrap select {
  padding:7px 30px 7px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:8px;
  color:var(--text-2);font-size:13px;outline:none;cursor:pointer;
  appearance:none;-webkit-appearance:none;
  transition:all var(--dur);
}
.sort-wrap select:focus { border-color:var(--purple);color:var(--text); }
.sort-wrap .select-arrow { position:absolute;right:9px;pointer-events:none;color:var(--text-3); }

/* ── Main ── */
.main {
  position:relative;z-index:1;
  max-width:1440px;margin:0 auto;
  padding:28px 28px 100px;
}

/* ── Toolbar + Search ── */
.toolbar { margin-bottom:20px; }
.search-wrap { position:relative;display:inline-flex;align-items:center;width:100%;max-width:420px; }
.search-ico  { position:absolute;left:14px;color:var(--text-3);pointer-events:none; }
.search-input {
  width:100%;padding:10px 40px 10px 42px;
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);font-size:14px;
  outline:none;backdrop-filter:blur(12px);
  transition:border-color var(--dur),box-shadow var(--dur);
}
.search-input:focus { border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,58,237,.18); }
.search-input::placeholder { color:var(--text-3); }
.search-clear { position:absolute;right:12px;background:none;border:none;color:var(--text-2);cursor:pointer;font-size:13px;padding:4px;transition:color var(--dur); }
.search-clear:hover { color:var(--text); }

/* ── Category tabs ── */
.cat-bar { display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px; }
.cat-tab {
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 16px;border-radius:20px;
  font-size:13px;font-weight:600;cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text-2);transition:all var(--dur) var(--ease);
}
.cat-tab:hover { color:var(--text);border-color:var(--border-hi);background:rgba(255,255,255,.07); }
.cat-tab.active { color:#fff; }
.cat-tab-icon { font-size:14px; }
.cat-count { opacity:.45;font-size:11px; }

/* ── Sounds grid ── */
.sounds-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(155px,1fr));
  gap:16px;
}

/* ── Sound card ── */
.sound-card {
  --c: #7c3aed;
  position:relative;aspect-ratio:1;
  border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--border);background:var(--surface);
  cursor:pointer;user-select:none;-webkit-user-select:none;
  touch-action:manipulation;
  transition:transform var(--dur) var(--ease),border-color var(--dur),box-shadow var(--dur);
}
.sound-card:hover { transform:translateY(-3px) scale(1.01);border-color:rgba(255,255,255,.15);box-shadow:0 12px 40px rgba(0,0,0,.4); }
.sound-card.playing { transform:scale(.96);border-color:var(--c);box-shadow:0 0 0 2px var(--c),0 0 40px color-mix(in srgb,var(--c) 50%,transparent); }

.card-img { position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .35s var(--ease); }
.sound-card:hover .card-img { transform:scale(1.07); }
.card-img-overlay { position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.05) 0%,rgba(0,0,0,.65) 100%); }
.card-default { position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:52px;background:linear-gradient(135deg,color-mix(in srgb,var(--c) 20%,transparent),color-mix(in srgb,var(--c) 8%,transparent)); }
.card-content { position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:11px 12px 12px; }
.card-name { font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:700;line-height:1.2;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.9);margin-bottom:5px;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.card-badge { display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 9px;border-radius:10px;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.12);width:fit-content;color:var(--c); }

/* Hold ring */
.hold-ring { position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;pointer-events:none; }
.sound-card.holding .hold-ring { opacity:1; }
.hold-ring svg { width:64px;height:64px;transform:rotate(-90deg); }
.hold-ring circle { fill:none;stroke:rgba(255,255,255,.85);stroke-width:3.5;stroke-dasharray:170;stroke-dashoffset:170;stroke-linecap:round;filter:drop-shadow(0 0 6px rgba(255,255,255,.5)); }
.sound-card.holding .hold-ring circle { animation:holdFill .55s ease-out forwards; }
@keyframes holdFill { to{stroke-dashoffset:0} }

/* Ripple */
@keyframes ripple { 0%{transform:scale(.93);opacity:.7} 100%{transform:scale(1.18);opacity:0} }
.play-ripple { position:absolute;inset:0;border-radius:inherit;border:2px solid var(--c);animation:ripple .55s ease-out forwards;pointer-events:none;z-index:3;filter:blur(.5px); }

/* Card action buttons */
.card-actions { position:absolute;top:8px;right:8px;display:flex;gap:5px;opacity:0;transition:opacity var(--dur);z-index:4; }
.sound-card:hover .card-actions { opacity:1; }
.card-btn { width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.55);backdrop-filter:blur(6px);color:rgba(255,255,255,.8);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all var(--dur); }
.card-btn.edit:hover { background:rgba(124,58,237,.75);border-color:var(--purple);color:#fff; }
.card-btn.del:hover  { background:rgba(239,68,68,.75);border-color:var(--red);color:#fff; }

/* Skeleton */
.skeleton { aspect-ratio:1;border-radius:var(--radius);background:linear-gradient(90deg,var(--surface) 0%,var(--surface-2) 50%,var(--surface) 100%);background-size:200% 100%;animation:shimmer 1.6s infinite; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* Empty state */
.empty-state { text-align:center;padding:100px 20px;display:flex;flex-direction:column;align-items:center;gap:12px; }
.empty-icon { font-size:64px;margin-bottom:4px;filter:grayscale(.3); }
.empty-state h3 { font-size:22px;font-weight:700; }
.empty-state p { color:var(--text-2);max-width:360px;line-height:1.6; }

/* ── Modal ── */
.modal-overlay { position:fixed;inset:0;z-index:200;background:rgba(0,0,10,.72);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s; }
.modal-overlay.open { opacity:1;pointer-events:all; }
.modal { background:linear-gradient(145deg,#0e0e22 0%,#0a0a1c 100%);border:1px solid rgba(124,58,237,.3);border-radius:22px;width:100%;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.6),0 0 60px rgba(124,58,237,.08);transform:scale(.94) translateY(12px);transition:transform .22s var(--ease);max-height:90vh;display:flex;flex-direction:column; }
.modal-overlay.open .modal { transform:scale(1) translateY(0); }
.modal-upload { max-width:460px; }
.modal-cats   { max-width:500px; }
.modal-edit   { max-width:460px; }
.modal-header { display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0; }
.modal-header h2 { font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;letter-spacing:1px; }
.modal-close { width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--dur); }
.modal-close:hover { color:var(--text);border-color:var(--border-hi);background:rgba(255,255,255,.08); }
.modal-body { padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:18px;flex:1; }
.modal-footer { padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;align-items:center;flex-shrink:0; }

/* ── Forms ── */
.form-field { display:flex;flex-direction:column;gap:7px; }
.form-field label { font-size:11.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-2); }
.form-field input,.form-field select { padding:10px 14px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;outline:none;transition:border-color var(--dur),box-shadow var(--dur);font-family:inherit; }
.form-field input:focus,.form-field select:focus { border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,58,237,.2); }
.form-field input::placeholder { color:var(--text-3); }
.form-hint { font-size:12px;color:var(--text-2);margin-top:-4px; }
.select-wrap { position:relative; }
.select-wrap select { width:100%;cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:36px; }
.select-wrap select option { background:#111128; }
.select-arrow { position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--text-2);pointer-events:none; }

/* ── Drop zone ── */
.dropzone { border:2px dashed rgba(124,58,237,.35);border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;background:rgba(124,58,237,.04);transition:all var(--dur); }
.dropzone:hover,.dropzone.drag-over { border-color:var(--purple);background:rgba(124,58,237,.09); }
.dropzone.has-file { border-style:solid;border-color:var(--green);background:rgba(16,185,129,.06); }
.dz-icon { font-size:34px;margin-bottom:8px; }
.dz-text { font-size:14px;color:var(--text-2);margin-bottom:4px; }
.dz-link { color:var(--purple);cursor:pointer;font-weight:600; }
.dz-hint { font-size:12px;color:var(--text-3); }
.dz-filename { font-size:14px;font-weight:600;color:var(--green);margin-bottom:4px;word-break:break-all; }

/* ── Image upload ── */
.img-drop-area { display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:var(--radius-sm);border:1px dashed var(--border);color:var(--text-2);font-size:13px;cursor:pointer;transition:all var(--dur); }
.img-drop-area:hover { border-color:var(--border-hi);background:rgba(255,255,255,.03); }
.img-preview { position:relative; }
.img-preview img { width:100%;max-height:140px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border); }
.img-remove { position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;background:rgba(239,68,68,.8);border:none;color:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background var(--dur); }
.img-remove:hover { background:var(--red); }

/* ── Edit image section ── */
.edit-img-section { display:flex;justify-content:center; }
.edit-img-wrap {
  position:relative;width:140px;height:140px;border-radius:14px;overflow:hidden;
  border:1px solid var(--border);background:var(--surface);
  cursor:pointer;
}
.edit-img-wrap:hover .edit-img-overlay { opacity:1; }
.edit-img-default { position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:48px;background:var(--surface-2); }
.edit-img-wrap img { position:absolute;inset:0;width:100%;height:100%;object-fit:cover; }
.edit-img-overlay {
  position:absolute;inset:0;
  background:rgba(0,0,0,.6);backdrop-filter:blur(2px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;transition:opacity var(--dur);
}
.edit-img-btn {
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:7px;border:none;
  background:rgba(255,255,255,.15);color:#fff;
  font-size:12px;font-weight:600;cursor:pointer;
  transition:background var(--dur);
}
.edit-img-btn:hover { background:rgba(255,255,255,.25); }
.edit-img-btn-remove:hover { background:rgba(239,68,68,.6) !important; }

/* ── Categories modal list ── */
.cat-list { display:flex;flex-direction:column;gap:7px;margin-bottom:22px; }
.cat-item { display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);background:rgba(255,255,255,.03);border:1px solid var(--border);transition:border-color var(--dur); }
.cat-item.editing { border-color:rgba(124,58,237,.4);background:rgba(124,58,237,.06); }
.cat-item-dot { width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor; }
.cat-item-icon { font-size:20px; }
.cat-item-name { flex:1;font-weight:600;font-size:15px; }
.cat-item-count { font-size:12px;color:var(--text-2); }

/* Cat item inline edit */
.cat-item-edit-row { display:flex;gap:6px;align-items:center;flex:1; }
.cat-item-edit-row input[type="text"] { flex:1;padding:5px 9px;background:rgba(255,255,255,.06);border:1px solid rgba(124,58,237,.4);border-radius:6px;color:var(--text);font-size:14px;outline:none;font-family:inherit; }
.cat-item-edit-row input[type="text"]:focus { border-color:var(--purple); }
.cat-item-edit-icon { width:36px;padding:5px 4px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:18px;text-align:center;outline:none;font-family:inherit; }
.cat-item-edit-color { width:36px;height:30px;border:1px solid var(--border);border-radius:6px;background:none;cursor:pointer;padding:2px; }
.cat-item-edit-color::-webkit-color-swatch-wrapper { padding:2px; }
.cat-item-edit-color::-webkit-color-swatch { border-radius:4px;border:none; }

.cat-item-btn { width:30px;height:30px;border-radius:7px;flex-shrink:0;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--dur); }
.cat-item-edit-btn { background:rgba(124,58,237,.1);border:1px solid rgba(124,58,237,.3);color:rgba(124,58,237,.8); }
.cat-item-edit-btn:hover { background:rgba(124,58,237,.25);color:#fff; }
.cat-item-save-btn { background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:rgba(16,185,129,.8); }
.cat-item-save-btn:hover { background:rgba(16,185,129,.25);color:#fff; }
.cat-item-del-btn { background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:rgba(239,68,68,.7); }
.cat-item-del-btn:hover { background:rgba(239,68,68,.25);color:#fff; }

.section-label { font-size:11.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-2);margin-bottom:10px; }
.add-cat-row { display:flex;gap:8px;align-items:center; }
.add-cat-name { flex:1;padding:9px 12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;outline:none;transition:border-color var(--dur);font-family:inherit; }
.add-cat-name:focus { border-color:var(--purple); }
.add-cat-name::placeholder { color:var(--text-3); }
.add-cat-icon { width:48px;padding:9px 4px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:20px;text-align:center;outline:none;cursor:pointer;transition:border-color var(--dur);font-family:inherit; }
.add-cat-icon:focus { border-color:var(--purple); }
.add-cat-color { width:40px;height:38px;border:1px solid var(--border);border-radius:8px;background:none;cursor:pointer;padding:2px; }
.add-cat-color::-webkit-color-swatch-wrapper { padding:2px; }
.add-cat-color::-webkit-color-swatch { border-radius:5px;border:none; }

/* ── Toasts ── */
.toasts { position:fixed;bottom:28px;right:28px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none; }
.toast { padding:11px 18px;border-radius:10px;font-size:13.5px;font-weight:500;backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);max-width:320px;pointer-events:all;animation:toastSlide .3s var(--ease); }
@keyframes toastSlide { from{transform:translateX(110%);opacity:0} to{transform:translateX(0);opacity:1} }
@keyframes toastOut   { from{transform:translateX(0);opacity:1} to{transform:translateX(110%);opacity:0} }
.toast.success { background:rgba(16,185,129,.14);border-color:rgba(16,185,129,.35);color:#34d399; }
.toast.error   { background:rgba(239,68,68,.14); border-color:rgba(239,68,68,.35); color:#f87171; }
.toast.info    { background:rgba(6,182,212,.12);  border-color:rgba(6,182,212,.35);  color:var(--cyan); }

/* ── Scrollbar ── */
::-webkit-scrollbar { width:5px;height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,.09);border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:rgba(255,255,255,.16); }

/* ── Responsive ── */
@media (max-width:768px) {
  .navbar { padding:0 16px;height:56px; }
  .brand-name { font-size:18px;letter-spacing:3px; }
  .main { padding:16px 14px 90px; }
  .sounds-grid { grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px; }
  .card-actions { opacity:1; }
  .admin-menu { right:16px; }
}
@media (max-width:600px) {
  .modal-overlay { align-items:flex-end;padding:0; }
  .modal { border-radius:22px 22px 0 0;max-height:92vh; }
  .modal-upload,.modal-cats,.modal-edit { max-width:100%; }
  .brand-name { display:none; }
  .sounds-grid { grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px; }
  .toasts { left:14px;right:14px;bottom:14px; }
  .toast { max-width:100%; }
  .add-cat-row { flex-wrap:wrap; }
  .add-cat-name { flex-basis:100%; }
}
