:root{--text:#50463c;--text-h:#1f1b16;--bg:#f7efe3;--border:#3e2c161f;--accent:#0a5f54;--shadow:0 24px 60px #3d291324;--sans:"Avenir Next", "Trebuchet MS", sans-serif;--heading:"Iowan Old Style", "Palatino Linotype", serif;font:18px/1.45 var(--sans);letter-spacing:.01em;color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#ecd49d99,#0000 24%),linear-gradient(135deg,#f7efe3,#f4e0c8 44%,#f3ecd6)}*{box-sizing:border-box}html{min-height:100%}body{min-height:100vh;margin:0}button,textarea{font:inherit}#root{min-height:100vh}h1,h2,h3{font-family:var(--heading);color:var(--text-h);font-weight:700}h1{letter-spacing:-.04em;font-size:clamp(1.9rem,min(4vw,5.2vh),3.4rem);line-height:1}p{margin:0}.app-shell{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);min-height:100svh;display:grid}.hero-panel,.results-panel{padding:clamp(1rem,2.4vh,2.6rem)}.hero-panel{flex-direction:column;justify-content:center;gap:clamp(.8rem,1.7vh,1.5rem);display:flex}.eyebrow,.shuffle-label,.count-label,.team-heading span{text-transform:uppercase;letter-spacing:.16em;font-size:.78rem}.eyebrow{color:var(--accent);margin:0}h1{max-width:14ch;margin:0}.intro{max-width:34rem;font-size:clamp(.95rem,1.6vh,1.1rem)}.control-panel{border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow);background:#faf4e9c2;border-radius:28px;padding:clamp(.9rem,1.8vh,1.4rem)}.input-label,.validation-copy,.count-value,.team-heading p,.team-card li,.launch-button,.status-banner,.signal-pill{color:var(--text-h)}.input-label{margin-bottom:.75rem;display:inline-block}.names-input{resize:vertical;box-sizing:border-box;width:100%;min-height:clamp(10rem,27vh,16rem);max-height:34vh;font:inherit;color:var(--text-h);background:#fffcf7e0;border:1px solid #362d1d24;border-radius:20px;padding:1rem 1.1rem;line-height:1.5}.names-input:focus-visible{outline-offset:2px;outline:2px solid #0a5f54a6}.team-heading,.dramatic-board{justify-content:space-between;align-items:center;gap:1rem;display:flex}.control-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.2rem;margin-top:1rem;display:flex}.control-row-meta{grid-template-rows:auto auto;grid-auto-columns:max-content;grid-auto-flow:column;align-items:center;gap:.55rem 1.75rem;display:grid}.meta-block{grid-template-rows:subgrid;grid-row:span 2;align-items:center;display:grid}.meta-block .count-label{align-self:end;margin:0}.meta-block .count-value{align-self:center;margin:0}.count-value{margin:.15rem 0 0;font-size:clamp(1.6rem,3.2vh,2.2rem);font-weight:600;line-height:1}.launch-button{font:inherit;cursor:pointer;color:#f8f2e8;background:linear-gradient(135deg,#0a5f54,#178f6f);border:0;border-radius:999px;padding:1rem 1.5rem;font-weight:600;transition:transform .18s,box-shadow .18s,opacity .18s;box-shadow:0 18px 28px #0a5f5440}.launch-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 22px 36px #0a5f544d}.launch-button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.status-banner,.signal-pill{border-radius:999px;align-items:center;width:fit-content;margin-top:1rem;padding:.65rem 1rem;font-weight:600;display:inline-flex}.status-idle,.signal-idle{background:#ccab5829}.status-shuffling,.signal-shuffling{background:#c757262e;animation:.72s ease-in-out infinite pulse}.status-revealed,.signal-revealed{background:#0a5f5429}.validation-copy{margin:1rem 0 0;transition:color .18s}.validation-copy-warning{color:#b3501e;font-weight:600}.team-count-options{flex-wrap:wrap;gap:.5rem;display:flex}.team-count-chip{color:var(--text-h);min-width:2.6rem;font:inherit;cursor:pointer;background:#fffcf7eb;border:1px solid #362d1d29;border-radius:999px;padding:.45rem .95rem;font-weight:600;transition:background .16s,border-color .16s,color .16s,transform .16s}.team-count-chip:hover:not(:disabled):not(.team-count-chip-active){border-color:#0a5f5480;transform:translateY(-1px)}.team-count-chip-active{color:#f8f2e8;background:linear-gradient(135deg,#0a5f54,#178f6f);border-color:#0000;box-shadow:0 10px 18px #0a5f5438}.team-count-chip:disabled{opacity:.5;cursor:not-allowed}.results-panel{color:#dce7ec;background:radial-gradient(circle at 100% 0,#215f8342,#0000 35%),radial-gradient(circle at 0 100%,#dfa14b47,#0000 32%),#10212a;flex-direction:column;justify-content:center;display:flex}.dramatic-board{margin-bottom:1.4rem}.shuffle-label{color:#f1c46f;margin:0}.signal-pill{color:#f5f0e7;margin-top:0}.team-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.1rem;display:grid}.team-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.team-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.team-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.team-grid-5{grid-template-columns:repeat(6,minmax(0,1fr));gap:.8rem}.team-grid-5 .team-card{grid-column:span 2}.team-grid-5 .team-card:nth-child(4){grid-column:2/span 2}.team-grid-5 .team-card:nth-child(5){grid-column:4/span 2}.team-grid-6{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem}.team-card{border-radius:28px;min-height:clamp(14rem,37vh,24rem);padding:1.3rem;position:relative;overflow:hidden}.team-grid-4 .team-card,.team-grid-5 .team-card,.team-grid-6 .team-card{border-radius:22px;min-height:clamp(10rem,22vh,16rem);padding:1rem}.team-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff26,#0000 26%);position:absolute;inset:0}.amber-card{background:linear-gradient(#e6b15ef5,#a95b1ef5)}.blue-card{background:linear-gradient(#58a2dbf5,#1a4b89f5)}.green-card{background:linear-gradient(#74bf82f5,#1e6d49f5)}.purple-card{background:linear-gradient(#a682d7f5,#52338af5)}.red-card{background:linear-gradient(#e17575f5,#922731f5)}.cyan-card{background:linear-gradient(#6cc4c8f5,#1c6975f5)}.team-heading p{margin:0;font-size:1.4rem}.team-card ul{gap:.75rem;margin:1.2rem 0 0;padding:0;list-style:none;display:grid}.team-card li{background:#fff8efc7;border-radius:18px;padding:clamp(.6rem,1.2vh,.9rem) 1rem;font-weight:600;animation:.24s slideUp}@media (height<=900px) and (width>=981px){.hero-panel,.results-panel{padding-block:.75rem}.control-row,.dramatic-board,.team-heading{gap:.65rem}.names-input{max-height:30vh}.status-banner,.signal-pill{margin-top:.6rem;padding:.5rem .85rem}.team-card ul{gap:.55rem;margin-top:.8rem}}.team-card .placeholder{color:#10212abd;background:#fff8ef66}@media (width<=980px){.app-shell{grid-template-columns:1fr}.hero-panel,.results-panel{padding:2rem 1.2rem}.team-grid,.team-grid-2,.team-grid-3,.team-grid-4,.team-grid-5,.team-grid-6{grid-template-columns:1fr}.team-grid-5 .team-card,.team-grid-5 .team-card:nth-child(4),.team-grid-5 .team-card:nth-child(5){grid-column:auto}h1{max-width:12ch}.control-row,.dramatic-board,.team-heading{flex-direction:column;align-items:flex-start}.launch-button{width:100%}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #c757263d}50%{transform:scale(1.02);box-shadow:0 0 0 12px #c7572600}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
