:root{
  --bg:#050914;--bg2:#09111f;--panel:#0d1524cc;--panel2:#111b2edd;--line:#223047;--text:#f7f8ff;--muted:#a9b3c9;--soft:#78849e;
  --purple:#8b2cff;--purple2:#b832ff;--cyan:#48d7ff;--green:#40d875;--red:#ff4d67;--yellow:#ffb84d;--shadow:0 24px 80px rgba(0,0,0,.45);--radius:18px;
}
body[data-theme="light"]{--bg:#f4f6fb;--bg2:#ffffff;--panel:#ffffffdd;--panel2:#f7f8ff;--line:#dde3f1;--text:#101728;--muted:#5f6b82;--soft:#7a849a;--shadow:0 24px 80px rgba(35,45,80,.16)}
*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at 20% 0%,rgba(139,44,255,.28),transparent 30%),radial-gradient(circle at 85% 12%,rgba(72,215,255,.12),transparent 30%),linear-gradient(180deg,var(--bg) 0%,#07101f 45%,var(--bg) 100%);color:var(--text);min-height:100vh;overflow-x:hidden}body[data-theme="light"]{background:radial-gradient(circle at 20% 0%,rgba(139,44,255,.13),transparent 30%),linear-gradient(180deg,#f7f8ff,#edf1fb)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}.hidden{display:none!important}.site-bg{position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:56px 56px;mask-image:linear-gradient(to bottom,black,transparent 75%)}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:34px;padding:18px 34px;background:rgba(5,9,20,.82);border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(18px)}body[data-theme="light"] .topbar{background:rgba(255,255,255,.82);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:-.04em;font-size:28px}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--purple),var(--purple2));box-shadow:0 0 24px rgba(139,44,255,.5);font-weight:900;font-size:30px}.main-nav{display:flex;align-items:center;gap:8px;flex:1}.main-nav a{padding:14px 18px;border-radius:12px;color:#dbe2f3;font-weight:600;position:relative}body[data-theme="light"] .main-nav a{color:#2d3953}.main-nav a:hover,.main-nav a.active{color:#fff;background:rgba(139,44,255,.12)}body[data-theme="light"] .main-nav a:hover,body[data-theme="light"] .main-nav a.active{color:#111;background:rgba(139,44,255,.12)}.main-nav a.active::after{content:"";position:absolute;left:18px;right:18px;bottom:-19px;height:3px;background:linear-gradient(90deg,var(--purple),var(--purple2));border-radius:99px}.top-actions{display:flex;align-items:center;gap:10px}.search-box{display:flex;align-items:center;gap:10px;padding:0 14px;border:1px solid var(--line);background:rgba(12,20,36,.75);border-radius:12px;height:48px;min-width:260px}body[data-theme="light"] .search-box{background:#fff}.search-box input{background:transparent;border:0;outline:0;color:var(--text);width:100%}.icon-btn,.profile-chip{border:1px solid var(--line);background:rgba(12,20,36,.75);color:var(--text);border-radius:12px;height:48px;min-width:48px}.profile-chip{background-size:cover;background-position:center}.user-badge{padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.06);font-weight:700;white-space:nowrap}
.layout{position:relative;display:grid;grid-template-columns:290px minmax(0,1fr) 330px;gap:24px;padding:28px;max-width:1780px;margin:0 auto}.left-rail,.right-rail{display:flex;flex-direction:column;gap:24px}.panel{background:linear-gradient(180deg,var(--panel),rgba(9,16,31,.72));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(18px)}body[data-theme="light"] .panel{background:var(--panel);border-color:var(--line)}.panel h2{font-size:16px;text-transform:none;margin:0 0 18px}.left-rail .panel,.right-rail .panel{padding:20px}.wide{padding:0}.primary-btn,.secondary-btn,.tool-btn{border:0;border-radius:14px;font-weight:800;color:white;padding:14px 18px}.primary-btn{background:linear-gradient(135deg,var(--purple),var(--purple2));box-shadow:0 14px 35px rgba(139,44,255,.32)}.secondary-btn,.tool-btn{background:rgba(255,255,255,.08);border:1px solid var(--line);color:var(--text)}.danger{color:#ffc1c8;border-color:rgba(255,77,103,.5)}.full{width:100%}.content{display:flex;flex-direction:column;gap:24px}.hero-card{display:flex;justify-content:space-between;gap:24px;align-items:center;background:linear-gradient(180deg,rgba(17,27,46,.88),rgba(9,16,31,.72));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:26px 32px;box-shadow:var(--shadow)}body[data-theme="light"] .hero-card{background:#fff;border-color:var(--line)}.hero-title-row{display:flex;gap:22px;align-items:center}.category-icon{display:grid;place-items:center;width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,var(--purple),var(--purple2));font-size:25px}.eyebrow{margin:0 0 6px;color:#d77cff;font-weight:800}.hero-card h1{margin:0;font-size:32px;letter-spacing:-.04em}.muted{color:var(--muted)}.small{font-size:13px}.hero-metrics{display:flex;gap:32px}.hero-metrics div{display:flex;flex-direction:column;align-items:flex-end}.hero-metrics strong{font-size:25px}.hero-metrics span{color:var(--muted);font-size:13px}.category-list{display:flex;flex-direction:column;gap:8px}.category-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:0;background:transparent;color:var(--text);padding:13px 14px;border-radius:14px;width:100%;text-align:left}.category-item:hover,.category-item.active{background:linear-gradient(90deg,rgba(139,44,255,.35),rgba(139,44,255,.06))}.category-item .left{display:flex;align-items:center;gap:12px;font-weight:750}.pill{background:rgba(255,255,255,.1);padding:4px 9px;border-radius:99px;font-size:12px}.stat-line{display:flex;justify-content:space-between;padding:10px 0;color:var(--muted)}.stat-line strong{color:var(--text)}.avatar-stack{display:flex;align-items:center;min-height:42px}.avatar-stack span,.mini-avatar,.author-avatar{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#22314d,#10182b);border:2px solid rgba(255,255,255,.08);font-weight:900;background-size:cover;background-position:center}.avatar-stack span{margin-left:-8px}.avatar-stack span:first-child{margin-left:0}.active-users{display:flex;flex-direction:column;gap:10px}.active-user{display:flex;align-items:center;gap:10px}.active-user .dot{width:9px;height:9px;border-radius:50%;background:var(--green)}
.composer-card{padding:18px}.composer-head{display:flex;gap:14px;align-items:center}.composer-fake{flex:1;text-align:left;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--muted);border-radius:18px;padding:16px 18px}.composer-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}.composer-actions button{border:0;background:rgba(255,255,255,.06);color:var(--text);border-radius:14px;padding:12px;font-weight:700}.tabs{display:flex;gap:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:8px;width:max-content}.tab{border:0;background:transparent;color:var(--muted);font-weight:800;padding:12px 18px;border-radius:12px}.tab.active{background:rgba(139,44,255,.20);color:#f0d6ff}.thread-item{display:grid;grid-template-columns:46px minmax(0,1fr) auto;gap:14px;align-items:start;padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.08)}.thread-item:last-child{border-bottom:0}.thread-item:hover{background:rgba(139,44,255,.06)}.thread-item h3{margin:0 0 7px;font-size:17px}.thread-item p{margin:0;color:var(--muted);font-size:14px;line-height:1.45}.thread-stats{display:flex;gap:18px;color:var(--muted);font-size:13px}.author-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.badge{font-size:11px;padding:3px 7px;border-radius:999px;background:rgba(139,44,255,.25);color:#e9c8ff;font-weight:900}.profile-link{font-weight:800;color:#fff}body[data-theme="light"] .profile-link{color:#151a2e}.media-badge{font-size:12px;color:#cba6ff}.empty{padding:48px;text-align:center;color:var(--muted)}.breadcrumb{display:flex;gap:10px;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.08);color:var(--muted)}.breadcrumb button{border:0;background:transparent;color:#d77cff;font-weight:800}.thread-main{padding:24px 28px;border-bottom:1px solid rgba(255,255,255,.08)}.thread-head{display:flex;justify-content:space-between;gap:18px}.thread-head h2{font-size:28px;margin:0 0 8px}.thread-body{white-space:pre-wrap;line-height:1.65;color:#edf1ff}.reply-count{padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.post{display:grid;grid-template-columns:46px minmax(0,1fr);gap:14px;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.post-body{white-space:pre-wrap;line-height:1.55}.reply-form{display:flex;flex-direction:column;gap:12px;padding:20px 24px}.reply-form textarea,.modal-card textarea,.modal-card input,.modal-card select{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);border-radius:14px;padding:14px;outline:0}body[data-theme="light"] .reply-form textarea,body[data-theme="light"] .modal-card textarea,body[data-theme="light"] .modal-card input,body[data-theme="light"] .modal-card select{background:#fff;color:#101728}.composer-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.composer-tools .primary-btn{margin-left:auto}.media-preview,.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;margin-top:12px}.media-card{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:rgba(255,255,255,.05)}.media-card img{width:100%;height:160px;object-fit:cover;display:block}.media-card a{display:block;padding:12px;color:#e4cdff;font-weight:800;word-break:break-word}.media-card iframe{width:100%;aspect-ratio:16/9;border:0;display:block}.media-card .media-caption{padding:10px;color:var(--muted);font-size:13px}.popular-list{margin:0;padding-left:20px}.popular-list li{padding:9px 0;color:var(--muted)}.popular-list strong{display:block;color:var(--text);font-weight:800}.tags{display:flex;flex-wrap:wrap;gap:9px}.tags span{padding:8px 10px;border-radius:999px;background:rgba(139,44,255,.14);border:1px solid rgba(139,44,255,.35);color:#efd8ff;font-size:13px}.user-month{text-align:center}.spotlight-avatar,.big-avatar{display:grid;place-items:center;width:86px;height:86px;border-radius:50%;margin:10px auto;background:linear-gradient(135deg,var(--purple),var(--cyan));border:3px solid rgba(255,255,255,.14);font-size:30px;font-weight:900;background-size:cover;background-position:center}.user-month h3{margin:8px 0 4px}.modal{border:0;background:transparent;padding:0;width:min(760px,calc(100vw - 24px));max-height:90vh}.modal::backdrop{background:rgba(0,0,0,.72);backdrop-filter:blur(5px)}.modal-card{position:relative;background:linear-gradient(180deg,#111b2f,#09111f);border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:var(--shadow);color:var(--text);max-height:90vh;overflow:auto}.small-modal{width:min(520px,calc(100vw - 24px))}body[data-theme="light"] .modal-card{background:#fff}.modal-card label{display:flex;flex-direction:column;gap:8px;margin:14px 0;font-weight:750}.close-btn{position:absolute;right:18px;top:14px;border:0;background:transparent;color:var(--muted);font-size:28px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:18px}.form-message{min-height:22px;color:#ffd7a1}.profile-editor-grid{display:grid;grid-template-columns:170px 1fr;gap:22px}.stacked-fields{display:flex;flex-direction:column}.upload-avatar{display:block;text-align:center;border:1px dashed var(--line);padding:12px;border-radius:14px;color:#e8cfff}.links-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}.toast{position:fixed;right:24px;bottom:24px;background:#111b2f;border:1px solid var(--line);color:var(--text);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);z-index:50}.footer{display:flex;gap:22px;justify-content:center;color:var(--muted);padding:28px}
@media(max-width:1180px){.layout{grid-template-columns:240px minmax(0,1fr)}.right-rail{grid-column:1/-1;display:grid;grid-template-columns:repeat(2,1fr)}.topbar{flex-wrap:wrap}.main-nav{order:3;flex-basis:100%;overflow:auto}.main-nav a.active::after{display:none}}@media(max-width:820px){.layout{grid-template-columns:1fr;padding:16px}.left-rail,.right-rail{display:flex}.topbar{padding:14px}.search-box{min-width:0;flex:1}.brand-text{font-size:22px}.hero-card,.thread-head{flex-direction:column;align-items:flex-start}.composer-actions,.links-grid,.profile-editor-grid{grid-template-columns:1fr}.thread-item{grid-template-columns:42px 1fr}.thread-stats{grid-column:2}}

/* === INC Forum V3: Sound Cards + Admin === */
:root{
  --magenta:#ff4fd8;--orange:#ff9f43;--blue:#44b7ff;--deep:#070a18;
}
.sound-btn{margin-top:10px;border:0;border-radius:14px;font-weight:900;color:white;padding:14px 18px;background:linear-gradient(135deg,var(--cyan),var(--purple),var(--magenta));box-shadow:0 14px 36px rgba(72,215,255,.22)}
.admin-blocks-host{display:flex;flex-direction:column;gap:14px}.admin-blocks-host:empty{display:none}.admin-block{border:1px solid rgba(255,255,255,.10);border-radius:20px;background:linear-gradient(135deg,rgba(255,79,216,.12),rgba(72,215,255,.08));padding:18px;overflow:hidden}.admin-block h2,.admin-block h3{margin-top:0}.soundcards-hub{display:flex;flex-direction:column;gap:24px}.sound-hero{display:flex;justify-content:space-between;align-items:center;gap:22px;padding:26px 30px;background:radial-gradient(circle at 10% 0%,rgba(255,79,216,.18),transparent 34%),radial-gradient(circle at 85% 10%,rgba(72,215,255,.20),transparent 32%),linear-gradient(180deg,rgba(17,27,46,.92),rgba(7,10,24,.86))}.sound-hero h2{font-size:32px;letter-spacing:-.04em;margin:0 0 8px}.sound-hero-actions{display:flex;gap:12px;flex-wrap:wrap}.sound-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px}.sound-map-panel{min-height:680px;overflow:hidden}.map-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.sound-map{position:relative;height:620px;overflow:hidden;background:radial-gradient(circle at 50% 50%,rgba(139,44,255,.16),transparent 36%),linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:auto,44px 44px,44px 44px;border-radius:0 0 var(--radius) var(--radius);touch-action:none}.sound-map svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.sound-node{position:absolute;width:174px;min-height:132px;border:1px solid rgba(255,255,255,.15);border-radius:22px;background:linear-gradient(160deg,rgba(15,24,42,.96),rgba(38,20,70,.92));box-shadow:0 18px 55px rgba(0,0,0,.35),0 0 35px rgba(139,44,255,.16);padding:12px;cursor:grab;user-select:none;transform:translate(-50%,-50%);transition:box-shadow .18s,border-color .18s}.sound-node:active{cursor:grabbing}.sound-node:hover{border-color:rgba(255,79,216,.55);box-shadow:0 22px 70px rgba(0,0,0,.45),0 0 48px rgba(255,79,216,.24)}.sound-node .cover{width:100%;height:72px;border-radius:15px;background:linear-gradient(135deg,var(--purple),var(--cyan));object-fit:cover;margin-bottom:9px}.sound-node h3{font-size:14px;line-height:1.15;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sound-node p{margin:4px 0 0;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sound-node .genre-chip{display:inline-block;margin-top:8px;padding:5px 8px;border-radius:999px;background:rgba(255,79,216,.16);border:1px solid rgba(255,79,216,.3);font-size:11px;color:#ffd7f8}.sound-side{padding:20px}.sound-filter{display:flex;flex-direction:column;gap:8px;margin:0 0 14px;font-weight:800}.sound-filter input{border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);border-radius:14px;padding:12px;outline:0}.sound-card-list{display:flex;flex-direction:column;gap:12px;max-height:560px;overflow:auto;padding-right:4px}.sound-card-mini{border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(255,255,255,.045);padding:12px;display:grid;grid-template-columns:54px minmax(0,1fr);gap:12px}.sound-card-mini img,.sound-card-mini .mini-cover{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--purple),var(--cyan));object-fit:cover}.sound-card-mini h3{font-size:14px;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sound-card-mini p{margin:0;color:var(--muted);font-size:12px}.sound-card-mini .mini-actions{grid-column:1/-1;display:flex;gap:8px;flex-wrap:wrap}.sound-card-mini a,.sound-card-mini button{border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);border-radius:10px;padding:7px 9px;font-size:12px;font-weight:800}.sound-card-mini button.danger{color:#ffc3c9}.sound-modal-card{display:grid;grid-template-columns:160px minmax(0,1fr);gap:18px}.sound-modal-cover{width:160px;height:160px;border-radius:26px;object-fit:cover;background:linear-gradient(135deg,var(--purple),var(--cyan));box-shadow:0 18px 60px rgba(139,44,255,.28)}.sound-meta{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.sound-meta span{padding:7px 10px;border-radius:99px;background:rgba(72,215,255,.11);border:1px solid rgba(72,215,255,.28);font-size:12px}.sound-platform-link{display:inline-block;margin-top:14px}.sound-form-grid,.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.admin-card code{background:rgba(255,255,255,.08);padding:2px 6px;border-radius:7px}.admin-tools{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.admin-preview{margin-top:14px;border:1px dashed rgba(255,255,255,.22);border-radius:18px;min-height:80px;padding:14px;background:rgba(255,255,255,.035)}.admin-preview:empty::before{content:"Anteprima vuota";color:var(--muted)}.feed-sound-card{border-left:3px solid var(--magenta)}.thread-item.feed-sound-card h3::before{content:"◆ ";color:var(--magenta)}
@media(max-width:1100px){.sound-layout{grid-template-columns:1fr}.sound-side{order:-1}.sound-map-panel{min-height:560px}.sound-map{height:520px}}@media(max-width:760px){.sound-hero,.sound-modal-card{grid-template-columns:1fr;display:block}.sound-form-grid,.admin-grid{grid-template-columns:1fr}.sound-node{width:150px}.sound-layout{gap:16px}}


/* === INC Forum V3.1 — Sound Cards separate, Segnale-inspired === */
:root{--green:#1ed760;--signal:#23ff8e;--acid:#c6ff3d;--void:#020707;}
body{background:radial-gradient(circle at 14% 10%,rgba(139,44,255,.30),transparent 28%),radial-gradient(circle at 86% 8%,rgba(30,215,96,.18),transparent 30%),linear-gradient(180deg,#050914 0%,#041015 52%,#050914 100%)}
.main-nav #navSoundCards{background:linear-gradient(135deg,rgba(30,215,96,.14),rgba(139,44,255,.16));border:1px solid rgba(30,215,96,.20)}
.categories-panel{margin-top:0}.sound-entry-card{position:relative;display:grid;gap:14px;padding:18px;border-radius:22px;border:1px solid rgba(35,255,142,.24);background:radial-gradient(circle at 20% 0%,rgba(30,215,96,.22),transparent 40%),linear-gradient(180deg,rgba(8,22,22,.92),rgba(8,12,26,.92));box-shadow:0 24px 70px rgba(0,0,0,.36),0 0 38px rgba(30,215,96,.10);overflow:hidden;cursor:pointer}.sound-entry-card::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:26px 26px;opacity:.55;pointer-events:none}.sound-entry-card>*{position:relative}.sound-entry-orb{display:grid;place-items:center;width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,var(--signal),var(--cyan),var(--purple));font-size:26px;color:#06110d;box-shadow:0 0 34px rgba(30,215,96,.32)}.sound-entry-card span{color:var(--signal);font-weight:950;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.sound-entry-card h2{font-size:25px;margin:3px 0 6px;letter-spacing:-.04em}.sound-entry-card p{margin:0;color:var(--muted);line-height:1.45;font-size:13px}.sound-btn{background:linear-gradient(135deg,var(--signal),var(--cyan));color:#04110c;box-shadow:0 14px 40px rgba(30,215,96,.24);font-weight:950}.sound-btn:hover,.sound-primary:hover{filter:brightness(1.08)}
.soundcards-hub{gap:26px}.signal-hero-forum{display:grid;grid-template-columns:minmax(0,1.2fr) 340px;gap:24px;align-items:stretch}.signal-copy,.compact-oracle{position:relative;border:1px solid rgba(35,255,142,.22);border-radius:28px;background:radial-gradient(circle at 86% 16%,rgba(30,215,96,.16),transparent 30%),linear-gradient(135deg,rgba(7,20,22,.92),rgba(11,16,35,.88));box-shadow:0 26px 90px rgba(0,0,0,.36);padding:34px;overflow:hidden}.signal-copy::before{content:"SEGNALE 01";position:absolute;right:24px;bottom:8px;color:rgba(255,255,255,.035);font-size:72px;font-weight:950;letter-spacing:-.08em}.signal-copy h2{font-size:clamp(48px,7vw,92px);line-height:.88;letter-spacing:-.07em;margin:8px 0 12px;text-transform:uppercase}.tagline{font-size:22px;color:#f1fff7;font-weight:850;margin:0 0 16px}.release-kicker{display:inline-block;color:var(--signal);font-size:12px;text-transform:uppercase;letter-spacing:.14em;font-weight:950}.compact-oracle h3{font-size:30px;line-height:.98;text-transform:uppercase;letter-spacing:-.05em;margin:14px 0}.compact-oracle p{color:var(--muted);line-height:1.6}.signal-legend-mini{display:flex;gap:15px;flex-wrap:wrap;margin-top:22px;color:#d5ddda;font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.legend-line{display:inline-block;width:44px;margin-right:8px;vertical-align:middle;border-top:2px solid rgba(30,215,96,.85);box-shadow:0 0 18px rgba(30,215,96,.38)}.legend-line.medium{opacity:.62}.legend-line.weak{opacity:.35;border-top-style:dashed}.sound-primary{border:0;border-radius:15px;font-weight:950;color:#04110c;padding:14px 18px;background:linear-gradient(135deg,var(--signal),var(--acid));box-shadow:0 16px 42px rgba(30,215,96,.24);display:inline-flex;justify-content:center;align-items:center;text-align:center}.signal-layout-forum{display:grid;grid-template-columns:minmax(0,1.45fr) 360px;gap:24px}.signal-map-panel,.signal-form-panel{border-color:rgba(35,255,142,.18);background:linear-gradient(180deg,rgba(8,18,25,.88),rgba(5,10,18,.82))}.panel-header.map-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:0 0 18px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px}.panel-header.map-header h3,.signal-form-panel h3{font-size:30px;text-transform:uppercase;letter-spacing:-.05em;margin:6px 0 0}.map-actions{display:flex;gap:10px;flex-wrap:wrap}.ghost-button,.map-btn{border:1px solid rgba(35,255,142,.22);background:rgba(0,0,0,.20);color:#eafff2;border-radius:12px;padding:10px 13px;font-weight:850}.signal-toolbar{display:grid;grid-template-columns:180px minmax(0,1fr);gap:12px;align-items:end;padding:0;margin-bottom:16px;border:0}.signal-toolbar label{display:grid;gap:7px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.10em;font-weight:900}.signal-toolbar input,.signal-toolbar select{border:1px solid rgba(35,255,142,.18);background:rgba(0,0,0,.22);color:var(--text);border-radius:13px;padding:12px;outline:0}.map-help{grid-column:1/-1;margin:0;color:var(--muted);font-size:12px}.signal-map{height:720px;min-height:620px;border-radius:26px;border:1px solid rgba(35,255,142,.24);background:radial-gradient(circle at 20% 24%,rgba(30,215,96,.16),transparent 24%),radial-gradient(circle at 78% 64%,rgba(91,124,255,.14),transparent 28%),linear-gradient(135deg,rgba(2,7,7,.96),rgba(5,16,24,.96));box-shadow:inset 0 0 80px rgba(30,215,96,.08),0 26px 90px rgba(0,0,0,.38);overflow:hidden}.constellation-bg{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.46) 1px,transparent 1.6px),radial-gradient(circle,rgba(30,215,96,.34) 1px,transparent 1.8px),linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:92px 92px,147px 147px,64px 64px,64px 64px;opacity:.72;mask-image:radial-gradient(circle at center,black 12%,transparent 92%)}.sound-links,.sound-nodes{position:absolute;inset:0;width:100%;height:100%}.sound-nodes{pointer-events:none}.sound-link{stroke-linecap:round;fill:none;stroke-dasharray:10 16;animation:signal-wave 5.5s linear infinite}.sound-link.strong{stroke:rgba(30,215,96,.86);stroke-width:2.8;filter:drop-shadow(0 0 9px rgba(30,215,96,.8));animation:signal-wave 3.2s linear infinite,signal-pulse-strong 1.7s ease-in-out infinite}.sound-link.medium{stroke:rgba(30,215,96,.48);stroke-width:1.8;filter:drop-shadow(0 0 6px rgba(30,215,96,.42));animation:signal-wave 4.4s linear infinite,signal-pulse-medium 2.6s ease-in-out infinite}.sound-link.weak{stroke:rgba(255,255,255,.20);stroke-width:1.2;stroke-dasharray:5 15;animation:signal-wave 6.8s linear infinite,signal-pulse-weak 3.4s ease-in-out infinite}@keyframes signal-wave{from{stroke-dashoffset:0}to{stroke-dashoffset:-260}}@keyframes signal-pulse-strong{0%,100%{opacity:.62}50%{opacity:1}}@keyframes signal-pulse-medium{0%,100%{opacity:.34}50%{opacity:.72}}@keyframes signal-pulse-weak{0%,100%{opacity:.16}50%{opacity:.38}}
.signal-node{pointer-events:auto;position:absolute;width:210px;min-height:250px;transform:translate(-50%,-50%);border-radius:22px;border:1px solid rgba(35,255,142,.24);background:linear-gradient(180deg,rgba(30,215,96,.16),rgba(0,0,0,.32)),rgba(8,18,18,.86);box-shadow:0 20px 60px rgba(0,0,0,.38),0 0 24px rgba(30,215,96,.10);backdrop-filter:blur(14px);overflow:hidden;cursor:pointer;user-select:none;transition:border-color .2s,box-shadow .2s,transform .2s}.signal-node:hover{border-color:rgba(30,215,96,.78);box-shadow:0 28px 80px rgba(0,0,0,.45),0 0 42px rgba(30,215,96,.24)}.sound-node-cover{width:100%;aspect-ratio:1/1;background:rgba(255,255,255,.055);display:grid;place-items:center}.sound-node-cover img{width:100%;height:100%;object-fit:cover}.sound-node-cover span{color:var(--signal);font-size:3rem;font-weight:950}.sound-node-body{padding:14px}.sound-node-title{display:block;font-size:15px;line-height:1.15;text-transform:uppercase;letter-spacing:.04em}.sound-node-artist{display:block;margin-top:6px;color:var(--muted);font-size:13px;font-weight:850}.sound-node-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.sound-node-tags span{border:1px solid rgba(30,215,96,.28);border-radius:999px;padding:4px 8px;color:rgba(245,247,246,.82);background:rgba(30,215,96,.08);font-size:11px}.sound-empty-map{position:absolute;inset:0;display:grid;place-content:center;text-align:center;color:var(--muted);padding:30px}.sound-empty-map h3{color:var(--text);font-size:28px;margin:0 0 8px}.signal-form-panel{padding:22px}.signal-mini{border-color:rgba(35,255,142,.14);background:rgba(30,215,96,.045)}.signal-mini .mini-cover{display:grid;place-items:center;color:var(--signal);font-size:22px}.sound-card-list{max-height:690px}.sound-card-mini a,.sound-card-mini button{border-color:rgba(35,255,142,.20)}.sound-detail-shell{border-color:rgba(35,255,142,.24);background:linear-gradient(180deg,rgba(30,215,96,.16),rgba(4,9,9,.96) 36%)}.signal-detail h2{font-size:clamp(36px,5vw,58px);line-height:.92;text-transform:uppercase;letter-spacing:-.06em}.empty-cover{display:grid;place-items:center;color:var(--signal);font-size:60px}.sound-card-form .modal-card,input,textarea{accent-color:var(--signal)}
@media(max-width:1220px){.signal-layout-forum,.signal-hero-forum{grid-template-columns:1fr}.signal-form-panel{order:-1}.signal-map{height:640px}}@media(max-width:820px){.signal-copy h2{font-size:52px}.signal-toolbar{grid-template-columns:1fr}.signal-node{width:165px;min-height:220px}.sound-entry-card{grid-template-columns:1fr}}

/* === V3.2 VISUAL QA FIX — Sound Cards hero/map alignment === */
.soundcards-hub,
.signal-hero-forum,
.signal-layout-forum,
.signal-map-panel,
.signal-form-panel,
.signal-copy,
.compact-oracle{
  min-width:0;
}

.signal-hero-forum{
  width:100%;
  gap:22px;
}

.signal-copy,
.compact-oracle{
  padding:clamp(22px,3.1vw,34px);
}

.signal-copy{
  isolation:isolate;
}

.signal-copy::before{
  z-index:0;
  right:clamp(14px,2vw,24px);
  bottom:clamp(8px,1.5vw,14px);
  max-width:90%;
  font-size:clamp(42px,7vw,72px);
  line-height:.82;
  white-space:nowrap;
  overflow:hidden;
}

.signal-copy > *{
  position:relative;
  z-index:1;
}

.signal-copy h2{
  max-width:100%;
  font-size:clamp(42px,5.4vw,76px);
  line-height:.92;
  letter-spacing:-.055em;
  margin:10px 0 14px;
  overflow-wrap:normal;
  text-wrap:balance;
}

.signal-copy .tagline,
.tagline{
  max-width:900px;
  font-size:clamp(18px,2vw,22px);
  line-height:1.18;
}

.signal-copy .muted,
.signal-copy p{
  max-width:900px;
  line-height:1.45;
}

.signal-legend-mini{
  align-items:center;
  row-gap:10px;
  column-gap:18px;
  margin-top:22px;
  max-width:100%;
}

.signal-legend-mini span{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
}

.legend-line{
  flex:0 0 44px;
}

.signal-map-panel{
  padding:clamp(16px,2vw,24px);
  overflow:hidden;
}

.panel-header.map-header{
  align-items:flex-start;
  gap:14px;
}

.panel-header.map-header > div:first-child{
  min-width:0;
}

.panel-header.map-header h3,
.signal-form-panel h3{
  font-size:clamp(24px,2.6vw,30px);
  line-height:1;
  overflow-wrap:break-word;
}

.map-actions{
  flex:0 0 auto;
  justify-content:flex-end;
}

.ghost-button,
.map-btn{
  white-space:nowrap;
}

.signal-toolbar{
  grid-template-columns:minmax(160px,180px) minmax(0,1fr);
  width:100%;
}

.signal-toolbar input,
.signal-toolbar select{
  min-width:0;
  width:100%;
}

.signal-map{
  position:relative;
  width:100%;
  max-width:100%;
}

.sound-empty-map{
  inset:0;
  padding:28px;
}

@media(max-width:1420px){
  .signal-copy h2{
    font-size:clamp(40px,4.7vw,66px);
    letter-spacing:-.05em;
  }
}

@media(max-width:1220px){
  .signal-hero-forum{
    grid-template-columns:1fr;
  }
  .compact-oracle{
    display:none;
  }
  .signal-copy h2{
    font-size:clamp(42px,7.2vw,72px);
  }
  .signal-copy::before{
    font-size:clamp(40px,8vw,68px);
  }
}

@media(max-width:900px){
  .signal-copy{
    padding:24px;
    border-radius:24px;
  }
  .signal-copy h2{
    font-size:clamp(38px,10.5vw,58px);
    line-height:.95;
  }
  .panel-header.map-header{
    flex-direction:column;
    align-items:stretch;
  }
  .map-actions{
    justify-content:flex-start;
  }
  .signal-toolbar{
    grid-template-columns:1fr;
  }
  .signal-map{
    height:620px;
    min-height:560px;
  }
}

@media(max-width:560px){
  .signal-copy{
    padding:20px;
  }
  .signal-copy h2{
    font-size:clamp(34px,12.5vw,46px);
    letter-spacing:-.045em;
  }
  .signal-copy .tagline,
  .tagline{
    font-size:17px;
  }
  .signal-legend-mini span{
    font-size:11px;
  }
  .legend-line{
    flex-basis:34px;
    width:34px;
  }
  .map-actions{
    width:100%;
  }
  .map-actions .ghost-button,
  .map-actions .map-btn{
    flex:1 1 calc(50% - 8px);
    text-align:center;
    justify-content:center;
  }
}


/* ===================== INC FORUM V3.3: roles, profile fields, classic thread view ===================== */
.user-badge.is-admin{background:linear-gradient(135deg,rgba(255,184,77,.22),rgba(139,44,255,.18));border:1px solid rgba(255,184,77,.35)}
.user-badge.is-artist{background:linear-gradient(135deg,rgba(30,215,96,.20),rgba(72,215,255,.12));border:1px solid rgba(30,215,96,.34)}
.category-item.restricted{position:relative;border:1px solid rgba(255,255,255,.03)}
.category-meta{display:flex;align-items:center;gap:8px;margin-left:auto;white-space:nowrap}
.category-meta em{font-style:normal;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#b9c3d8;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:4px 7px}
.category-item.active .category-meta em{color:#fff;background:rgba(139,44,255,.32)}
.profile-extra-grid textarea{min-height:94px;resize:vertical}
.profile-modal h3{margin:24px 0 10px;font-size:16px;letter-spacing:-.01em}
.profile-modal .small{margin-top:-4px;margin-bottom:12px}
.classic-thread-post{display:grid;grid-template-columns:210px minmax(0,1fr);gap:24px;align-items:start;padding:24px!important}
.classic-thread-post>.thread-head,.classic-thread-post>.thread-body,.classic-thread-post>.media-grid{grid-column:2}
.forum-user-card{align-self:stretch;position:sticky;top:96px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:18px 14px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,rgba(17,27,46,.88),rgba(8,14,26,.72));box-shadow:inset 0 0 30px rgba(139,44,255,.05)}
.forum-user-card .author-avatar.xl{width:76px;height:76px;font-size:26px;border-width:2px;background-size:cover;background-position:center}
.forum-user-card strong{font-size:15px;line-height:1.15}
.forum-user-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.35}
.forum-user-card small{color:var(--soft);font-size:12px;line-height:1.35}
.forum-user-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:4px}
.forum-user-chips span{font-size:10px;padding:4px 7px;border:1px solid rgba(30,215,96,.28);border-radius:999px;color:#d9ffe9;background:rgba(30,215,96,.08)}
.artist-badge{background:rgba(30,215,96,.18)!important;color:#caffdf!important}
.classic-reply-post{display:grid!important;grid-template-columns:190px minmax(0,1fr)!important;gap:20px!important;align-items:start;padding:20px 24px!important}
.classic-reply-post .forum-user-card{position:relative;top:auto;min-height:100%}
.forum-post-content{min-width:0;padding:4px 0}
.forum-signature{margin-top:18px;padding-top:14px;border-top:1px dashed rgba(255,255,255,.13);color:var(--soft);font-size:12px;line-height:1.45;white-space:pre-wrap}
@media(max-width:980px){.classic-thread-post,.classic-reply-post{grid-template-columns:1fr!important}.classic-thread-post>.thread-head,.classic-thread-post>.thread-body,.classic-thread-post>.media-grid{grid-column:1}.forum-user-card{position:relative;top:auto;align-items:flex-start;text-align:left}.forum-user-card .author-avatar.xl{width:58px;height:58px}.forum-user-chips{justify-content:flex-start}.profile-extra-grid{grid-template-columns:1fr!important}}
@media(max-width:560px){.classic-thread-post,.classic-reply-post{padding:16px!important}.category-meta em{display:none}.forum-user-card{padding:14px}}

/* ===================== INC FORUM V3.4: admin control, reactions, groups ===================== */
.admin-control-modal{width:min(1180px,calc(100vw - 28px));}
.admin-control-card{max-height:92vh;overflow:auto;padding:28px;}
.admin-control-head{display:flex;justify-content:space-between;gap:22px;align-items:flex-start;margin-bottom:22px;}
.admin-control-head h2{margin:.1rem 0 .45rem;font-size:clamp(1.8rem,4vw,3.2rem);line-height:.96;letter-spacing:-.055em;text-transform:uppercase;}
.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;padding:8px;margin:16px 0 18px;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:16px;}
.admin-tab{border:0;border-radius:12px;background:transparent;color:var(--muted);padding:11px 14px;font-weight:900;}
.admin-tab.active{background:linear-gradient(135deg,rgba(139,44,255,.26),rgba(72,215,255,.12));color:var(--text);}
.admin-tab-panel{display:none;}
.admin-tab-panel.active{display:block;}
.admin-panel-toolbar,.admin-inline-form{display:grid;grid-template-columns:minmax(180px,1fr) minmax(180px,.6fr) auto;gap:10px;margin-bottom:14px;align-items:end;}
.admin-inline-form{grid-template-columns:1.1fr 1fr .35fr .35fr auto;}
.admin-panel-toolbar input,.admin-panel-toolbar select,.admin-inline-form input,.admin-rules-form input,.admin-rules-form textarea,.admin-list input,.admin-list select,.admin-list textarea{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);border-radius:12px;padding:11px 12px;outline:0;}
.admin-list{display:grid;gap:10px;}
.admin-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.035);padding:14px;}
.admin-row h4{margin:0 0 5px;font-size:1rem;}
.admin-row p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.4;}
.admin-row-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.admin-row-actions button,.admin-row-actions select{min-height:36px;border-radius:10px;}
.admin-danger{border:1px solid rgba(255,77,103,.45)!important;color:#ffd1d7!important;background:rgba(255,77,103,.09)!important;}
.admin-warn{border:1px solid rgba(255,184,77,.45)!important;color:#ffe0b5!important;background:rgba(255,184,77,.08)!important;}
.embedded-admin-form{border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.16);border-radius:18px;padding:18px;margin-bottom:14px;}
.admin-rules-form{display:grid;gap:12px;}
.thread-admin-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px;}
.thread-admin-actions button{border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);border-radius:10px;padding:7px 9px;font-size:.78rem;font-weight:900;}
.reaction-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px;}
.reaction-btn{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.055);color:var(--muted);border-radius:999px;padding:7px 10px;font-weight:900;font-size:.82rem;}
.reaction-btn:hover,.reaction-btn.active{color:var(--text);border-color:rgba(139,44,255,.45);background:rgba(139,44,255,.14);}
.thread-item .reaction-bar{margin-top:10px;}
.thread-item .reaction-btn{padding:5px 8px;font-size:.75rem;}
.group-badge{background:rgba(72,215,255,.16);color:#c9f5ff;border:1px solid rgba(72,215,255,.28);}
.group-badge.artist-badge{background:rgba(30,215,96,.14);color:#d9ffe8;border-color:rgba(30,215,96,.30);}
.group-badge.scrittore{background:rgba(255,184,77,.14);color:#ffe1b5;border-color:rgba(255,184,77,.30);}
.group-badge.critico{background:rgba(184,50,255,.14);color:#f1d3ff;border-color:rgba(184,50,255,.30);}
.group-badge.ascoltatore{background:rgba(72,215,255,.14);color:#c9f5ff;border-color:rgba(72,215,255,.30);}
.user-group-note{font-size:.72rem;color:var(--muted);display:block;margin-top:6px;}
@media(max-width:900px){.admin-control-head,.admin-row{grid-template-columns:1fr;display:grid}.admin-panel-toolbar,.admin-inline-form{grid-template-columns:1fr}.admin-row-actions{justify-content:flex-start}.admin-control-card{padding:18px}.admin-control-head h2{font-size:2rem}}

/* ===================== Layout hardening: prevent label/badge overflow ===================== */
.topbar,
.layout,
.left-rail,
.right-rail,
.content,
.panel,
.hero-card,
.hero-title-row,
.hero-title-row > div,
.composer-head,
.composer-fake,
.composer-card,
.thread-view,
.admin-control-card,
.sound-entry-card,
.soundcards-hub{
  min-width:0;
}

.panel,
.hero-card,
.composer-card,
.thread-list,
.thread-view,
.sound-entry-card,
.admin-control-card{
  overflow-wrap:anywhere;
}

.top-actions{
  min-width:0;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.search-box{
  min-width:min(260px,100%);
}

.category-item{
  min-width:0;
  align-items:center;
  overflow:hidden;
}

.category-item .left{
  min-width:0;
  flex:1 1 auto;
}

.category-item .left > span:first-child{
  flex:0 0 auto;
}

.category-item .left > span:last-child{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  overflow-wrap:anywhere;
}

.category-meta{
  min-width:0;
  flex:0 1 auto;
  justify-content:flex-end;
}

.category-glyph{
  display:inline-grid;
  place-items:center;
  width:30px;
  height:30px;
  flex:0 0 30px;
  border-radius:10px;
  color:#f6f8ff;
  background:linear-gradient(135deg,rgba(139,44,255,.92),rgba(91,124,255,.78));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.13),0 10px 24px rgba(0,0,0,.18);
}

.category-glyph svg{
  width:18px;
  height:18px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.category-glyph[data-icon="music"]{background:linear-gradient(135deg,#1ed760,#0c8f51)}
.category-glyph[data-icon="announcements"]{background:linear-gradient(135deg,#ffb84d,#cc6d1d)}
.category-glyph[data-icon="writing"]{background:linear-gradient(135deg,#f59e0b,#7c3aed)}
.category-glyph[data-icon="science"]{background:linear-gradient(135deg,#48d7ff,#5b7cff)}
.category-glyph[data-icon="gaming"]{background:linear-gradient(135deg,#ff4fd8,#8b2cff)}
.category-glyph[data-icon="code"]{background:linear-gradient(135deg,#22d3ee,#2563eb)}
.category-glyph[data-icon="design"]{background:linear-gradient(135deg,#fb7185,#8b5cf6)}
.category-glyph[data-icon="ai"]{background:linear-gradient(135deg,#a3e635,#06b6d4)}
.category-glyph[data-icon="offtopic"]{background:linear-gradient(135deg,#64748b,#334155)}

.category-icon{
  font-size:0;
}

.category-icon .category-glyph{
  width:58px;
  height:58px;
  border-radius:20px;
  flex-basis:58px;
  box-shadow:0 0 28px rgba(139,44,255,.34);
}

.category-icon .category-glyph svg{
  width:31px;
  height:31px;
  stroke-width:1.7;
}

.category-meta em{
  max-width:96px;
  overflow:hidden;
  text-overflow:ellipsis;
}

.pill{
  flex:0 0 auto;
}

.active-user > div,
.popular-list li,
.thread-item > div,
.post > div,
.classic-thread-post > *,
.classic-reply-post > *,
.sound-card-mini > div,
.admin-row > div{
  min-width:0;
}

.active-user strong,
.popular-list strong,
.thread-item h3,
.thread-item p,
.sound-card-mini h3,
.sound-card-mini p,
.admin-row h4,
.admin-row p{
  overflow-wrap:anywhere;
}

.thread-stats{
  flex:0 0 auto;
  white-space:nowrap;
}

.tabs{
  max-width:100%;
  width:fit-content;
  flex-wrap:wrap;
}

.tab,
.primary-btn,
.secondary-btn,
.tool-btn,
.sound-btn,
.sound-primary,
.ghost-button,
.map-btn{
  min-width:0;
  overflow-wrap:anywhere;
}

.modal-actions{
  flex-wrap:wrap;
}

.modal-actions > *{
  min-width:0;
}

.admin-panel-toolbar,
.admin-inline-form,
.sound-form-grid,
.admin-grid,
.links-grid,
.profile-editor-grid{
  min-width:0;
}

.admin-panel-toolbar > *,
.admin-inline-form > *,
.sound-form-grid > *,
.admin-grid > *,
.links-grid > *,
.profile-editor-grid > *{
  min-width:0;
}

@media(max-width:1180px){
  .layout{
    grid-template-columns:minmax(220px,240px) minmax(0,1fr);
  }
}

@media(max-width:920px){
  .top-actions{
    width:100%;
    justify-content:flex-start;
  }

  .top-actions .search-box{
    flex:1 1 220px;
  }

  .user-badge{
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
  }
}

@media(max-width:560px){
  .category-item{
    gap:8px;
    padding:12px;
  }

  .category-meta{
    gap:6px;
  }

  .category-meta em{
    max-width:72px;
    padding-inline:6px;
  }

  .pill{
    padding-inline:8px;
  }

  .thread-item{
    grid-template-columns:42px minmax(0,1fr);
    padding:16px;
  }

  .thread-stats{
    white-space:normal;
    flex-wrap:wrap;
  }

.composer-tools .primary-btn{
    margin-left:0;
  }

  .hero-card{
    padding:20px;
  }

  .hero-title-row{
    align-items:flex-start;
    gap:14px;
  }

  .category-icon{
    width:48px;
    height:48px;
    border-radius:16px;
    flex:0 0 auto;
  }

  .hero-card h1{
    font-size:28px;
  }

  .hero-metrics{
    width:100%;
    gap:16px;
    justify-content:flex-start;
    flex-wrap:wrap;
  }

  .hero-metrics div{
    align-items:flex-start;
  }

  .composer-head{
    align-items:flex-start;
  }

  .composer-fake{
    padding:14px;
  }
}

/* ===================== Groups and theme consistency ===================== */
.group-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  padding:5px 9px;
  border-radius:999px;
  font-size:10px;
  line-height:1;
  font-weight:950;
  letter-spacing:.09em;
  text-transform:uppercase;
}

.forum-user-card .group-badge{
  margin-top:-4px;
}

.group-badge.artista,
.group-badge.artist-badge{
  color:#d7ffe7;
  background:rgba(30,215,96,.18);
  border-color:rgba(30,215,96,.42);
}

.group-badge.scrittore{
  color:#ffe3b8;
  background:rgba(255,184,77,.18);
  border-color:rgba(255,184,77,.44);
}

.group-badge.critico{
  color:#f1d4ff;
  background:rgba(184,50,255,.18);
  border-color:rgba(184,50,255,.42);
}

.group-badge.ascoltatore{
  color:#cdf4ff;
  background:rgba(72,215,255,.17);
  border-color:rgba(72,215,255,.42);
}

.group-badge.visitatore{
  color:#e3e9f8;
  background:rgba(148,163,184,.16);
  border-color:rgba(148,163,184,.34);
}

body[data-theme="light"]{
  --bg:#f4f7fb;
  --bg2:#ffffff;
  --panel:#ffffffee;
  --panel2:#f7f9ff;
  --line:#dce4f2;
  --text:#101728;
  --muted:#5f6b82;
  --soft:#748096;
  --shadow:0 20px 60px rgba(37,49,76,.12);
  background:
    radial-gradient(circle at 16% 8%,rgba(139,44,255,.12),transparent 30%),
    radial-gradient(circle at 86% 10%,rgba(30,215,96,.08),transparent 30%),
    linear-gradient(180deg,#f8fbff 0%,#eef4f8 52%,#f8fbff 100%);
}

body[data-theme="light"] .site-bg{
  background-image:
    linear-gradient(rgba(16,23,40,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(16,23,40,.045) 1px,transparent 1px);
}

body[data-theme="light"] .topbar,
body[data-theme="light"] .search-box,
body[data-theme="light"] .icon-btn,
body[data-theme="light"] .profile-chip,
body[data-theme="light"] .user-badge{
  background:rgba(255,255,255,.86);
  color:var(--text);
  border-color:var(--line);
}

body[data-theme="light"] .panel,
body[data-theme="light"] .hero-card,
body[data-theme="light"] .composer-card,
body[data-theme="light"] .thread-view,
body[data-theme="light"] .modal-card,
body[data-theme="light"] .admin-control-card,
body[data-theme="light"] .signal-map-panel,
body[data-theme="light"] .signal-form-panel{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,250,255,.9));
  color:var(--text);
  border-color:var(--line);
  box-shadow:var(--shadow);
}

body[data-theme="light"] .hero-card,
body[data-theme="light"] .thread-item,
body[data-theme="light"] .thread-main,
body[data-theme="light"] .reply-count,
body[data-theme="light"] .post,
body[data-theme="light"] .breadcrumb,
body[data-theme="light"] .map-toolbar,
body[data-theme="light"] .panel-header.map-header{
  border-color:var(--line);
}

body[data-theme="light"] .composer-fake,
body[data-theme="light"] .composer-actions button,
body[data-theme="light"] .secondary-btn,
body[data-theme="light"] .tool-btn,
body[data-theme="light"] .ghost-button,
body[data-theme="light"] .map-btn,
body[data-theme="light"] .sound-card-mini a,
body[data-theme="light"] .sound-card-mini button,
body[data-theme="light"] .thread-admin-actions button,
body[data-theme="light"] .reaction-btn{
  background:rgba(16,23,40,.045);
  color:var(--text);
  border-color:var(--line);
}

body[data-theme="light"] .tabs,
body[data-theme="light"] .admin-tabs,
body[data-theme="light"] .admin-row,
body[data-theme="light"] .embedded-admin-form,
body[data-theme="light"] .admin-preview,
body[data-theme="light"] .media-card,
body[data-theme="light"] .sound-card-mini{
  background:rgba(255,255,255,.7);
  border-color:var(--line);
}

body[data-theme="light"] .thread-item:hover,
body[data-theme="light"] .category-item:hover,
body[data-theme="light"] .category-item.active,
body[data-theme="light"] .tab.active,
body[data-theme="light"] .reaction-btn:hover,
body[data-theme="light"] .reaction-btn.active,
body[data-theme="light"] .admin-tab.active{
  background:rgba(139,44,255,.11);
  color:var(--text);
}

body[data-theme="light"] .thread-body,
body[data-theme="light"] .post-body,
body[data-theme="light"] .profile-link,
body[data-theme="light"] .popular-list strong{
  color:var(--text);
}

body[data-theme="light"] .badge{
  background:rgba(139,44,255,.12);
  color:#5a1bb3;
}

body[data-theme="light"] .pill,
body[data-theme="light"] .tags span,
body[data-theme="light"] .sound-meta span{
  background:rgba(16,23,40,.06);
  color:var(--text);
  border-color:rgba(16,23,40,.09);
}

body[data-theme="light"] .reply-form textarea,
body[data-theme="light"] .modal-card textarea,
body[data-theme="light"] .modal-card input,
body[data-theme="light"] .modal-card select,
body[data-theme="light"] .signal-toolbar input,
body[data-theme="light"] .signal-toolbar select,
body[data-theme="light"] .sound-filter input,
body[data-theme="light"] .admin-panel-toolbar input,
body[data-theme="light"] .admin-panel-toolbar select,
body[data-theme="light"] .admin-inline-form input,
body[data-theme="light"] .admin-rules-form input,
body[data-theme="light"] .admin-rules-form textarea,
body[data-theme="light"] .admin-list input,
body[data-theme="light"] .admin-list select,
body[data-theme="light"] .admin-list textarea{
  background:#fff;
  color:var(--text);
  border-color:var(--line);
}

body[data-theme="light"] .forum-user-card,
body[data-theme="light"] .sound-entry-card,
body[data-theme="light"] .signal-copy,
body[data-theme="light"] .compact-oracle{
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(242,248,250,.9));
  border-color:var(--line);
  box-shadow:var(--shadow);
}

body[data-theme="light"] .signal-copy h2,
body[data-theme="light"] .compact-oracle h3,
body[data-theme="light"] .tagline,
body[data-theme="light"] .signal-legend-mini,
body[data-theme="light"] .sound-entry-card h2{
  color:var(--text);
}

body[data-theme="light"] .signal-map,
body[data-theme="light"] .sound-map{
  background:
    radial-gradient(circle at 20% 24%,rgba(30,215,96,.11),transparent 24%),
    radial-gradient(circle at 78% 64%,rgba(91,124,255,.10),transparent 28%),
    linear-gradient(135deg,rgba(245,252,248,.96),rgba(237,244,250,.96));
  border-color:rgba(30,170,96,.22);
  box-shadow:inset 0 0 60px rgba(30,215,96,.06),var(--shadow);
}

body[data-theme="light"] .signal-node,
body[data-theme="light"] .sound-node{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(236,247,242,.94));
  color:var(--text);
  border-color:rgba(30,170,96,.24);
}

body[data-theme="light"] .modal::backdrop{
  background:rgba(15,23,42,.28);
}

body[data-theme="light"] .toast{
  background:#fff;
  color:var(--text);
  border-color:var(--line);
}

body[data-theme="light"] .group-badge.artista,
body[data-theme="light"] .group-badge.artist-badge{
  color:#116b36;
  background:rgba(30,215,96,.16);
  border-color:rgba(30,145,80,.26);
}

body[data-theme="light"] .group-badge.scrittore{
  color:#8a520d;
  background:rgba(255,184,77,.18);
  border-color:rgba(198,126,30,.28);
}

body[data-theme="light"] .group-badge.critico{
  color:#7b20a6;
  background:rgba(184,50,255,.14);
  border-color:rgba(136,40,190,.25);
}

body[data-theme="light"] .group-badge.ascoltatore{
  color:#0f6f8d;
  background:rgba(72,215,255,.15);
  border-color:rgba(28,144,176,.24);
}

body[data-theme="light"] .group-badge.visitatore{
  color:#475569;
  background:rgba(100,116,139,.12);
  border-color:rgba(100,116,139,.22);
}

/* ===================== V4 composer, previews and role profile cards ===================== */
#threadDialog{
  width:min(1120px,calc(100vw - 24px));
}

#threadForm.composer-real{
  display:grid;
  gap:16px;
}

.composer-pro-head{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  padding-right:38px;
}

.composer-pro-head h2{
  margin:.1rem 0 .35rem;
  font-size:clamp(2rem,4vw,3.35rem);
  line-height:.92;
  letter-spacing:-.055em;
  text-transform:uppercase;
}

.status-toggle{
  min-width:170px;
  margin:0!important;
}

.field-helper{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin:-8px 0 4px;
  color:var(--soft);
  font-size:12px;
  font-weight:800;
}

.composer-toolbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:10px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  background:rgba(255,255,255,.035);
}

.composer-toolbar button{
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:8px 10px;
  font-weight:950;
  min-width:38px;
}

.composer-side-pane{
  display:grid;
  grid-template-columns:1fr 1fr 1.25fr;
  gap:12px;
  align-items:stretch;
}

.rules-box,
.link-preview-box,
.post-preview-box,
.external-search-box{
  border:1px solid rgba(255,255,255,.09);
  border-radius:16px;
  background:rgba(255,255,255,.035);
  padding:14px;
  min-width:0;
}

.rules-box h3,
.link-preview-box h3,
.post-preview-box h3,
.profile-role-box h3{
  margin:0 0 10px;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.rules-box ul{
  margin:0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.55;
  font-size:13px;
}

.link-preview-box a{
  display:block;
  color:#d9fff0;
  overflow-wrap:anywhere;
  font-weight:850;
}

.live-preview-card{
  display:grid;
  gap:8px;
  min-height:132px;
  border-radius:12px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.07);
  padding:12px;
}

.live-preview-card h4{
  margin:0;
  font-size:16px;
  overflow-wrap:anywhere;
}

.preview-body{
  color:var(--muted);
  line-height:1.55;
  overflow-wrap:anywhere;
}

.preview-body blockquote{
  margin:8px 0;
  padding:8px 10px;
  border-left:3px solid var(--purple);
  background:rgba(139,44,255,.10);
  border-radius:8px;
}

.preview-body code{
  background:rgba(255,255,255,.09);
  border-radius:6px;
  padding:2px 5px;
}

.preview-tags,
.saved-external-cards,
.external-results{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.preview-tags span{
  border:1px solid rgba(72,215,255,.22);
  background:rgba(72,215,255,.10);
  color:#d4f7ff;
  border-radius:999px;
  padding:5px 8px;
  font-size:12px;
  font-weight:850;
}

.profile-role-box{
  margin-top:18px;
  padding:16px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:18px;
  background:rgba(255,255,255,.03);
}

.external-search-box{
  display:grid;
  gap:12px;
  margin-top:12px;
}

.external-card{
  display:grid;
  grid-template-columns:54px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  width:100%;
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  background:rgba(0,0,0,.14);
  padding:10px;
}

.external-card img,
.external-cover{
  width:54px;
  height:76px;
  border-radius:9px;
  object-fit:cover;
  background:linear-gradient(135deg,var(--purple),var(--cyan));
}

.external-card strong,
.external-card p,
.external-card a{
  display:block;
  margin:0;
  overflow-wrap:anywhere;
}

.external-card p{
  color:var(--muted);
  font-size:12px;
}

.external-card button{
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:8px 10px;
  font-weight:850;
}

body[data-theme="light"] .composer-toolbar,
body[data-theme="light"] .rules-box,
body[data-theme="light"] .link-preview-box,
body[data-theme="light"] .post-preview-box,
body[data-theme="light"] .profile-role-box,
body[data-theme="light"] .external-search-box,
body[data-theme="light"] .external-card,
body[data-theme="light"] .live-preview-card{
  background:rgba(255,255,255,.72);
  border-color:var(--line);
}

body[data-theme="light"] .composer-toolbar button,
body[data-theme="light"] .external-card button{
  background:#fff;
  color:var(--text);
  border-color:var(--line);
}

body[data-theme="light"] .link-preview-box a{
  color:#225ec5;
}

@media(max-width:900px){
  .composer-pro-head,
  .composer-side-pane{
    grid-template-columns:1fr;
    display:grid;
  }

  .status-toggle{
    min-width:0;
  }

  .external-card{
    grid-template-columns:48px minmax(0,1fr);
  }

  .external-card button{
    grid-column:1/-1;
  }
}

@media(max-width:560px){
  #threadForm.composer-real{
    padding:18px;
  }

  .composer-pro-head h2{
    font-size:2rem;
  }

  .field-helper{
    flex-direction:column;
    gap:4px;
  }
}
