:root{--gd:#0d3320;--gm:#155235;--gl:#1e7a4e;--gold:#f5c842;--gdk:#c9a415;--w:#fff;--ow:#f8faf6;--gr:#e2e8df;--tx:#1a2e1a;--tm:#5a7060;--r:12px;}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--gd);color:var(--tx);overflow-x:hidden}
.site-header{background:linear-gradient(160deg,#071f12,#0d3320 60%,#155235);border-bottom:3px solid var(--gold);padding:12px 16px;text-align:center;position:sticky;top:0;z-index:100}
.header-inner{display:flex;flex-direction:column;align-items:center;gap:8px;max-width:960px;margin:0 auto}
.site-header h1{font-size:1.5rem;font-weight:900;color:var(--gold);letter-spacing:-0.5px}
.header-right{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.subtitle{display:none}
.nav-btn{background:rgba(255,255,255,.1);color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.2);padding:6px 16px;border-radius:20px;text-decoration:none;font-size:.85rem;font-weight:600;transition:all .2s}
.nav-btn:hover,.nav-btn.active{background:var(--gold);color:var(--gd);border-color:var(--gold);font-weight:800}
.deadline-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(245,200,66,.12);border:1px solid rgba(245,200,66,.3);color:var(--gold);border-radius:20px;padding:4px 12px;font-size:.78rem;font-weight:700}
.container{max-width:960px;margin:0 auto;padding:10px 12px 20px}
.name-section{background:linear-gradient(135deg,#071f12,#0d3320);border-radius:var(--r);padding:12px 16px;margin-bottom:8px;display:flex;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.06)}
.name-section h2{font-size:.9rem;font-weight:900;color:var(--gold);white-space:nowrap}
.name-section p{display:none}
.name-section input{background:rgba(255,255,255,.96);border:1.5px solid transparent;font-size:16px;font-weight:600;flex:1;padding:9px 14px;border-radius:8px;color:var(--tx);-webkit-appearance:none}
.name-section input:focus{outline:none;border-color:var(--gold)}
.error-box{background:#fff8e1;border:2px solid #ffb300;border-radius:8px;padding:8px 14px;margin-bottom:8px;font-size:.9rem;color:#6d4c00;font-weight:600}
.names-banner{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 12px;margin-top:8px;font-size:.78rem;color:rgba(255,255,255,.65)}
.names-banner strong{color:var(--gold);display:block;margin-bottom:2px}
.group-nav{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;background:linear-gradient(135deg,#071f12,#0d3320);padding:10px 12px;border-radius:var(--r);border:1px solid rgba(255,255,255,.05)}
.grp-btn{padding:7px 13px;border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);color:rgba(255,255,255,.85);border-radius:8px;font-weight:800;cursor:pointer;font-size:.88rem;transition:all .15s}
.grp-btn:hover{background:rgba(255,255,255,.15)}
.grp-btn.active{background:var(--gold);color:#000;border-color:var(--gold);font-weight:900}
.grp-btn.grp-done{background:rgba(30,122,78,.55);border-color:#2ecc71;color:#a8ffcc}
.grp-btn.grp-done.active{background:var(--gold);color:var(--gd);border-color:var(--gold)}
.grp-btn.grp-partial{border-color:var(--gold);color:#fff}
.grp-layout{display:grid;grid-template-columns:1fr 240px;gap:12px;align-items:start}
.card{background:var(--w);border-radius:var(--r);box-shadow:0 2px 10px rgba(0,0,0,.08);padding:14px 16px;border:1px solid var(--gr)}
.card-title{font-size:.9rem;font-weight:800;color:var(--gd);margin-bottom:12px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.badge{background:var(--gd);color:var(--gold);font-size:.68rem;font-weight:800;padding:2px 8px;border-radius:16px}
.match-list{display:flex;flex-direction:column;gap:6px}
.match-row{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--ow);border-radius:8px;border:1.5px solid var(--gr);transition:border-color .15s}
.match-row:hover{border-color:#b8d4b0}
.match-row.picked{border-color:#a8d5b0;background:#f4faf5}
.match-date{font-size:.7rem;color:var(--tm);font-weight:700;min-width:42px;flex-shrink:0}
.match-teams{flex:1;display:flex;align-items:center;gap:6px;min-width:0}
.team{font-weight:700;font-size:.85rem;color:var(--gd);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vs{color:#b0bfb0;font-size:.7rem;font-weight:600;background:var(--gr);padding:2px 5px;border-radius:5px;flex-shrink:0}
.match-pick{display:flex;gap:4px;flex-shrink:0}
.pick-opt input{display:none}
.pick-opt span{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid var(--gr);border-radius:8px;font-weight:800;font-size:.88rem;cursor:pointer;transition:all .13s;color:var(--tm);background:var(--w)}
.pick-opt span:hover{border-color:#6dbf8a;color:var(--gd)}
.pick-opt input:checked + span{background:var(--gd);color:var(--gold);border-color:var(--gd);transform:scale(1.06)}
.gtab{width:100%;border-collapse:collapse;font-size:.8rem}
.gtab th{font-size:.68rem;font-weight:800;color:var(--tm);padding:5px;text-align:center;border-bottom:2px solid var(--gr)}
.gtab th:first-child{text-align:left}
.gtab td{padding:7px 5px;text-align:center;border-bottom:1px solid var(--gr);font-size:.8rem}
.gtab td:first-child{text-align:left;font-weight:700}
.gtab-pts{font-weight:900;color:var(--gd)}
.row-first td{background:#e8f5e9;color:#1b5e20}
.row-first td:first-child{font-weight:800}
.row-second td{background:#e3f2fd;color:#0d47a1}
.row-second td:first-child{font-weight:800}
.row-out td{color:var(--tm)}
.advance-info{margin-top:8px;display:flex;flex-wrap:wrap;gap:5px;padding-top:8px;border-top:1px solid var(--gr)}
.adv-badge{font-size:.73rem;font-weight:700;padding:3px 10px;border-radius:16px}
.adv-1{background:#c8e6c9;color:#1b5e20;border:1px solid #a5d6a7}
.adv-2{background:#bbdefb;color:#0d47a1;border:1px solid #90caf9}
.grp-nav-btns{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:8px;background:linear-gradient(135deg,#071f12,#0d3320);padding:9px 12px;border-radius:var(--r);border:1px solid rgba(255,255,255,.05)}
.btn-nav{padding:8px 16px;background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .15s}
.btn-nav:hover{background:rgba(255,255,255,.2)}
.btn-nav-gold{background:linear-gradient(135deg,var(--gold),var(--gdk));color:var(--gd);border-color:var(--gold)}
.grp-progress{font-size:.75rem;color:rgba(255,255,255,.55);font-weight:600;text-align:center}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.pcard{background:var(--ow);border:1.5px solid var(--gr);border-radius:10px;padding:12px}
.pmed{font-size:1.6rem;margin-bottom:3px}
.plab{font-weight:800;font-size:.85rem;color:var(--gd);margin-bottom:2px}
.ppts{font-size:.7rem;color:var(--tm);margin-bottom:8px;font-weight:600}
select,input[type=text],input[type=number]{width:100%;padding:8px 10px;border:1.5px solid var(--gr);border-radius:8px;font-size:16px;background:var(--w);color:var(--tx);transition:border-color .2s;font-family:inherit;-webkit-appearance:none}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
select:focus,input:focus{outline:none;border-color:var(--gl);box-shadow:0 0 0 3px rgba(30,122,78,.1)}
.tbcard{background:var(--w);border-radius:var(--r);padding:16px;margin-bottom:10px;border:1px solid var(--gr)}
.tbcard h3{color:var(--gd);font-weight:900;margin-bottom:4px;font-size:.95rem}
.tbcard p{font-size:.88rem;color:var(--tx);margin-bottom:8px}
.tbcard input{max-width:160px}
.btn-submit{display:block;width:100%;padding:15px;background:linear-gradient(135deg,var(--gold),var(--gdk));color:var(--gd);font-size:1rem;font-weight:900;border:none;border-radius:var(--r);cursor:pointer;box-shadow:0 4px 16px rgba(245,200,66,.3);transition:transform .15s;margin-top:8px}
.btn-submit:hover{transform:translateY(-2px)}
.ltab{width:100%;border-collapse:collapse;font-size:.9rem}
.ltab th{background:var(--gd);color:var(--gold);padding:10px 12px;text-align:left;font-weight:800;font-size:.73rem;letter-spacing:.8px;text-transform:uppercase}
.ltab th:first-child{border-radius:10px 0 0 0}.ltab th:last-child{border-radius:0 10px 0 0}
.ltab td{padding:10px 12px;border-bottom:1px solid var(--gr);vertical-align:middle}
.ltab tr:last-child td{border-bottom:none}
.gold-row td{background:#fffbea}.silver-row td{background:#f6f6f6}.bronze-row td{background:#fff4ee}
.ltab tbody tr:hover td{filter:brightness(.97)}
.rc{font-size:1rem;text-align:center;width:40px}
.name-cell{font-weight:700}
.pbanner{background:linear-gradient(135deg,#0d3320,#071f12);color:rgba(255,255,255,.8);border-radius:var(--r);padding:20px;margin-bottom:12px;text-align:center;border:1px solid rgba(255,255,255,.06)}
.scard{background:var(--w);border-radius:var(--r);padding:48px 32px;text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.12)}
.scard h2{font-size:1.7rem;font-weight:900;color:var(--gd);margin-bottom:8px}
.scard p{color:var(--tm);margin-bottom:22px}
.btn-sec{display:inline-block;padding:10px 24px;background:var(--gd);color:#fff;border-radius:8px;text-decoration:none;font-weight:700}
.btn-sec:hover{background:var(--gl)}
.agrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.agcard{background:var(--ow);border:1px solid var(--gr);border-radius:10px;padding:10px 12px}
.agcard h4{font-size:.74rem;font-weight:900;color:var(--gd);margin-bottom:7px;letter-spacing:.8px;text-transform:uppercase}
.arow{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.arow label{font-size:.72rem;font-weight:700;color:var(--tm);width:50px;flex-shrink:0}
.arow select,.arow input{flex:1;padding:5px 8px;font-size:.8rem}
.radlbl{display:block;padding:5px;border:1.5px solid var(--gr);border-radius:7px;font-size:.76rem;font-weight:800;text-align:center;cursor:pointer;transition:all .13s;color:var(--tm)}
.radlbl-active,.radmin:checked + .radlbl{background:var(--gd);color:var(--gold);border-color:var(--gd)}
.btn-adm{background:var(--gd);color:var(--gold);border:none;padding:10px 24px;border-radius:8px;font-weight:900;font-size:.9rem;cursor:pointer}
.btn-adm:hover{background:var(--gl)}
.msgbox{background:#d4edda;border:1px solid #b8ddc4;border-radius:8px;padding:10px 14px;margin-bottom:12px;color:#1b5e20;font-weight:600;font-size:.88rem}
@media(max-width:680px){
  .grp-layout{grid-template-columns:1fr}
  .grp-table{display:none}
  .pgrid{grid-template-columns:1fr 1fr}
  .agrid{grid-template-columns:1fr}
}
@media(max-width:500px){
  .header-inner{gap:6px}
  .site-header h1{font-size:1.2rem}
  .name-section{flex-direction:column;align-items:stretch}
  .name-section h2{text-align:center;font-size:.85rem}
  .name-section input{width:100%}
  .grp-layout{grid-template-columns:1fr}
  .match-date{min-width:36px;font-size:.65rem}
  .team{font-size:.8rem}
  .pick-opt span{width:32px;height:32px;font-size:.82rem}
  .pgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .match-row{flex-wrap:wrap;gap:6px;padding:10px 12px}
  .match-date{min-width:auto;width:100%;font-size:.7rem;color:var(--tm)}
  .match-teams{width:100%;justify-content:center;gap:8px}
  .team{font-size:.9rem;font-weight:800}
  .vs{font-size:.75rem}
  .match-pick{width:100%;justify-content:center;gap:10px}
  .pick-opt span{width:64px;height:40px;font-size:.95rem;border-radius:10px}
  .name-section{flex-direction:column;align-items:stretch}
  .name-section h2{text-align:center}
}
@media(max-width:600px){
  .group-nav{width:100%;max-width:100vw}
  .name-section{width:100%;max-width:100vw}
  .container{padding:10px 10px 20px;max-width:100vw}
  .name-section input{max-width:100%}
}
@media(min-width:681px){
  .container{padding-top:8px;padding-bottom:8px}
  .name-section{margin-bottom:6px}
  .group-nav{margin-bottom:6px;padding:8px 12px}
  .grp-btn{padding:5px 11px;font-size:.82rem}
  .card{padding:10px 14px}
  .card-title{margin-bottom:8px;font-size:.85rem}
  .match-list{gap:4px}
  .match-row{padding:7px 10px}
  .pick-opt span{width:33px;height:33px;font-size:.82rem}
  .grp-nav-btns{padding:7px 10px;margin-top:6px}
}
@media(max-width:600px){
  .hide-mobile{display:none}
  .ltab{font-size:.85rem}
  .ltab td,.ltab th{padding:9px 8px}
}
@media(max-width:600px){
  .hide-mobile{display:none}
  .ltab{font-size:.85rem}
  .ltab td,.ltab th{padding:9px 8px}
}
@media(max-width:600px){
  .hide-mobile{display:none !important}
}
.score-input{width:44px;height:38px;text-align:center;font-size:1.1rem;font-weight:800;padding:4px;border:1.5px solid var(--gr);border-radius:8px;background:var(--w);color:var(--tx);-moz-appearance:textfield}
.score-input::-webkit-outer-spin-button,.score-input::-webkit-inner-spin-button{-webkit-appearance:none}
.score-input:focus{outline:none;border-color:var(--gl);box-shadow:0 0 0 3px rgba(30,122,78,.1)}
.score-input.filled{border-color:var(--gd);background:#f4faf5}
.score-sep{font-weight:900;font-size:1.1rem;color:var(--tm);padding:0 2px}
.match-pick{display:flex;align-items:center;gap:4px;flex-shrink:0}
#modal-overlay{pointer-events:none}
#modal-overlay[style*="flex"]{pointer-events:all}
/* Schema och modal mobilanpassning */
@media(max-width:600px){
  .day-section{padding:10px 12px}
  .day-section .card-title{font-size:.9rem}
  /* Modal */
  #modal-overlay{padding:60px 6px 6px !important}
  #modal-header{padding:14px 16px 10px !important}
  #modal-content{padding:8px 14px 16px !important}
}

/* ===== Lekfull UX ===== */
/* Studsande boll i rubriken */
.ball{display:inline-block;animation:ballBounce 1.8s ease-in-out infinite;transform-origin:bottom center}
@keyframes ballBounce{0%,100%{transform:translateY(0) rotate(0)}25%{transform:translateY(-7px) rotate(12deg)}50%{transform:translateY(0) rotate(0)}55%{transform:translateY(-2px)}}

/* Pop-in på success-kort */
.pop-in{animation:popIn .5s cubic-bezier(.18,.89,.32,1.28)}
@keyframes popIn{from{opacity:0;transform:scale(.85) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* Studsande pokal */
.trophy-bounce{display:inline-block;animation:trophyB 2s ease-in-out infinite}
@keyframes trophyB{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(3deg)}}

/* Resultat-val: liten "pop" + studs */
.pick-opt input:checked + span{animation:pickPop .28s cubic-bezier(.18,.89,.32,1.28)}
@keyframes pickPop{0%{transform:scale(1)}45%{transform:scale(1.28)}100%{transform:scale(1.06)}}
.score-input.filled{animation:fieldPulse .3s ease}
@keyframes fieldPulse{0%{transform:scale(1)}50%{transform:scale(1.12)}100%{transform:scale(1)}}

/* Klar grupp får en glad puls i navet */
.grp-btn.grp-done{animation:doneFlash .5s ease}
@keyframes doneFlash{0%{box-shadow:0 0 0 0 rgba(46,204,113,.6)}100%{box-shadow:0 0 0 10px rgba(46,204,113,0)}}

/* Skicka-knappen lockar med en liten wiggle vid hover */
.btn-submit:hover{animation:wiggle .5s ease}
@keyframes wiggle{0%,100%{transform:translateY(-2px) rotate(0)}25%{transform:translateY(-2px) rotate(-1.5deg)}75%{transform:translateY(-2px) rotate(1.5deg)}}

/* Nav-knappar och sekundärknapp får lite mer liv */
.btn-sec{transition:transform .15s,background .2s}
.btn-sec:hover{transform:translateY(-2px) scale(1.03)}
.grp-btn{transition:all .15s,transform .12s}
.grp-btn:active{transform:scale(.92)}

/* Respektera användare som inte vill ha rörelse */
@media(prefers-reduced-motion:reduce){
  .ball,.trophy-bounce,.pop-in,.pick-opt input:checked + span,.score-input.filled,.grp-btn.grp-done,.btn-submit:hover{animation:none}
}