/* =========================
   Alkohopol – styles.css
   ========================= */

:root{
  --bg:#f6f0e3; --board:#f2e8d5; --line:#d7cbb7; --text:#222;
  --beer:#efe7a0; --wine:#e9c4f2; --liqueur:#f1d4cf; --spirit:#cfead6;
  --miser:#fff3b0; --jail:#ffd0d0; --go:#fffbe6;
  --primary:#4a7df6; --success:#27ae60; --muted:#6f7580;
  --r:16px; --shadow:0 10px 30px rgba(0,0,0,.14);
  --piece-size:44px; --ease:cubic-bezier(.2,.7,.2,1);
  
}

/* Base */
*{ box-sizing:border-box }
html,body{ height:100%; margin:0; background:var(--bg); color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif }
.app{ max-width:1000px; margin:18px auto; padding:0 12px }
.panel{ padding:14px; border:1px solid #0001; border-radius:var(--r); background:#fff; box-shadow:0 4px 16px #0000000f }

/* FAB */
.fab{
  position:fixed; right:16px; bottom:16px; width:54px; height:54px;
  border:none; border-radius:50%; background:#fff; box-shadow:var(--shadow);
  font-size:22px; cursor:pointer; display:grid; place-items:center; z-index:25;
}

/* Board */
.board-wrap{
  width:min(92vw,980px); aspect-ratio:5/4; margin:0 auto;
  background:var(--board); border:4px solid var(--line); border-radius:18px;
  position:relative; box-shadow:inset 0 0 0 3px #00000014;
  transform-origin:center; transition:transform .18s ease;
}
.board{
  position:absolute; inset:10px; display:grid;
  grid-template-columns:repeat(10,1fr); grid-template-rows:repeat(8,1fr); gap:3px;
}

/* Center */
.center-box{
  background:var(--board); border:2px dashed #0003; border-radius:16px;
  position:relative; display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.center-core{ position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; gap:6px; padding:12px 8px 8px; transform:translateY(4px) }
.center-box .logo{ width:clamp(240px,34vw,360px); height:auto; display:block; filter:drop-shadow(0 6px 14px rgba(0,0,0,.18)) }
.center-core .tagline{
  margin:-6px 0 2px; max-width:clamp(240px,34vw,360px); text-align:center;
  font-family:"Baloo 2",cursive; font-weight:700; font-size:clamp(14px,2.2vw,18px);
  color:#d64b4b; opacity:.95; text-shadow:0 0 6px rgba(214,75,75,.18), 0 1px 0 #fff;
}
.center-row{ display:flex; flex-wrap:wrap; align-items:flex-start; justify-content:center; gap:16px; margin-top:2px }

/* Misärhög (+ fallback) */
.cards-pile{ position:relative; width:clamp(80px,10.5vw,120px); aspect-ratio:3/4; cursor:pointer }
.cards-pile .card{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
  border-radius:12px; box-shadow:0 10px 24px rgba(0,0,0,.16);
  transition:transform .25s var(--ease), box-shadow .25s ease;
  background:
    radial-gradient(120% 100% at 110% -10%, rgba(0,0,0,.06), transparent 60%),
    linear-gradient(180deg, #fff8e8, #efe6d4);
  border:1px solid rgba(0,0,0,.08);
}
.cards-pile .card--shadow { transform:rotate(-7deg) translate(-8px,8px) scale(.98);  opacity:.95; z-index:1 }
.cards-pile .card--shadow2{ transform:rotate(5deg)  translate( 8px,6px)  scale(.985); opacity:.98; z-index:2 }
.cards-pile .card--top    { transform:rotate(-2deg); z-index:3; box-shadow:0 14px 30px rgba(0,0,0,.22) }
.cards-pile:hover .card--top{ transform:translateY(-8px) rotate(0) scale(1.04); box-shadow:0 20px 44px rgba(0,0,0,.28) }

/* Enhets-info */
.units-panel{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px;
  padding:10px 12px; display:flex; flex-direction:column; gap:6px; min-width:170px;
  box-shadow:0 8px 18px rgba(0,0,0,.08);
}
.unit{ display:flex; align-items:center; gap:10px; font-weight:800 }
.unit .u-ico{ font-size:20px; line-height:1; width:22px; text-align:center }

/* Kantetiketter */
.edge-label{
  position:absolute; z-index:1; pointer-events:none; user-select:none;
  font-family:"Baloo 2",cursive; font-weight:900; letter-spacing:.5px;
  text-shadow:0 2px 0 #fff, 0 6px 18px rgba(0,0,0,.22); opacity:.96;
}
.edge-label.e-bottom{ bottom:1.2%; left:50%; transform:translateX(-50%); font-size:clamp(24px,5.4vw,50px); color:#f4a400 }
.edge-label.e-top   { top:1.2%;    left:50%; transform:translateX(-50%); font-size:clamp(22px,5vw,46px);   color:#a15cc7 }
.edge-label.e-left  { left:-1.8%;  top:50%;  transform:translateY(-50%) rotate(-90deg); font-size:clamp(22px,5.4vw,52px); color:#e15656 }
.edge-label.e-right { right:-1.8%; top:50%;  transform:translateY(-50%) rotate(90deg);  font-size:clamp(22px,5.4vw,52px); color:#22a05a }

/* Tiles */
.cell{
  background:#fff; border:1px solid #0002; border-radius:8px;
  position:relative; display:flex; align-items:center; justify-content:center;
  padding:4px; overflow:hidden;
}
.tile{
  width:100%; height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:4px; padding:6px; text-align:center; font-weight:800;
}
.tile .icon{ font-size:18px }
.tile .name{ font-size:12px }
.tile .price,.tile small{ font-size:10px; color:#000a }
.prop{ border-top:8px solid #0005 }
.beer{background:var(--beer)} .wine{background:var(--wine)}
.liqueur{background:var(--liqueur)} .spirit{background:var(--spirit)}
.miser{background:var(--miser)} .jail{background:var(--jail)} .go{background:var(--go)}
.corner .name{ font-size:15px }
.rotL .tile{ transform:rotate(90deg) }
.rotT .tile{ transform:rotate(180deg) }
.rotR .tile{ transform:rotate(-90deg) }

/* Ägarsymboler */
.owner-bar{ position:absolute; left:4px; right:4px; bottom:4px; height:8px; border-radius:8px; opacity:0; transition:opacity .15s ease }
.owner-bar.show{ opacity:1 }
.owner-badge{
  position:absolute; top:6px; right:6px; width:28px; height:28px; border-radius:50%;
  display:grid; place-items:center; background:rgba(255,255,255,.95);
  box-shadow:0 2px 6px rgba(0,0,0,.25), inset 0 0 0 1px rgba(0,0,0,.06);
  opacity:0; transform:scale(.9); transition:opacity .15s ease, transform .15s ease; pointer-events:none; z-index:2;
}
.owner-badge.show{ opacity:1; transform:scale(1) }
.owner-badge img{ width:100%; height:100%; border-radius:50%; display:block; object-fit:cover }

/* Pjäser */
.piece{ width:var(--piece-size); height:var(--piece-size); position:absolute; transition:transform .18s linear; filter:drop-shadow(0 2px 3px rgba(0,0,0,.35)); z-index:5 }
.piece-inner{ width:var(--piece-size); height:var(--piece-size); display:flex; align-items:center; justify-content:center }
.piece img,.piece svg{ height:var(--piece-size); width:auto; max-width:calc(var(--piece-size) * 1.7); display:block; object-fit:contain }
.piece-hop{ animation:hop .46s cubic-bezier(.25,.8,.25,1) }
@keyframes hop{0%{transform:translateY(0) scale(1)}50%{transform:translateY(-12px) scale(1.06)}100%{transform:translateY(0) scale(1)}}
.spot{ position:absolute; inset:4px }
.spot .slot{ position:absolute; width:44px; height:40px }
.slot.s0{ left:4px;  bottom:4px } .slot.s1{ right:4px; bottom:4px }
.slot.s2{ left:4px;  top:4px }    .slot.s3{ right:4px; top:4px }

/* Overlays */
.overlay{ position:fixed; inset:0; background:rgba(15,19,32,.34); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .55s var(--ease); z-index:20 }
.overlay.open{ opacity:1; pointer-events:auto }
.overlay.hidden{ display:none }
.overlay.closing{ opacity:0; pointer-events:none }
.overlay-soft{ background:rgba(15,19,32,.28) }
@keyframes popIn{0%{opacity:0;transform:translateY(16px) scale(.94)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes popOut{to{opacity:0;transform:translateY(10px) scale(.98)}}
.overlay .modal,.overlay .control-modal,.overlay .toast{ opacity:0; transform:translateY(12px) scale(.97) }
.overlay.open .modal,.overlay.open .toast,.overlay.open .control-modal{ animation:popIn .50s var(--ease) both }
.overlay.closing .modal,.overlay.closing .toast,.overlay.closing .control-modal{ animation:popOut .40s ease both }

/* Setup-overlay */
#setup-overlay .modal{ width:min(880px,92vw); background:#fff !important; border-radius:24px; box-shadow:var(--shadow); overflow:hidden; display:flex; flex-direction:column }

/* Glasiga modaler (köp/drick/duell/roulette/misär) */
.control-modal,.modal.glassy{
  background:linear-gradient(180deg, rgba(255,255,255,.62) 0%, rgba(255,255,255,.50) 100%);
  backdrop-filter:blur(12px) saturate(140%); -webkit-backdrop-filter:blur(12px) saturate(140%);
  border:1px solid rgba(255,255,255,.38); border-radius:22px;
  box-shadow:0 24px 60px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.45);
}

/* Header/knappar */
.modal-header,.control-head{ display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid #00000010 }
.modal:not(.glassy) .modal-header{ background:#fff }
.modal.glassy .modal-header,.control-head{ background:linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.45)); border-bottom:1px solid rgba(0,0,0,.06) }
.icon-btn{ border:1px solid rgba(0,0,0,.06); background:rgba(255,255,255,.65); border-radius:12px; padding:.5rem .7rem; font-weight:800; cursor:pointer }

/* Kontroll-overlay */
.control-modal{ width:min(740px,96vw); min-height:410px; border-radius:22px; overflow:hidden }
.dice-wrap{ display:flex; gap:32px; align-items:center; justify-content:center; padding:32px 24px; cursor:pointer }
.die3d{ width:96px; height:96px; background:#fff; border-radius:18px; border:2px solid #1112; box-shadow:inset 0 2px 0 #fff,0 8px 22px rgba(0,0,0,.28),0 2px 0 #0002; position:relative }
.pip{ position:absolute; width:12px; height:12px; border-radius:50%; background:#111 }

/* Köp/Drick */
.modal-body{ padding:18px 20px }
.modal-footer{ display:flex; align-items:center; gap:10px; padding:16px 20px; border-top:1px solid #00000010 }
.buy-info{ display:flex; flex-direction:column; gap:8px }
.buy-info .big{ font-size:18px; font-weight:800 }
.buy-info .tag{ display:inline-block; padding:.2rem .5rem; border-radius:999px; border:1px solid #0001; background:#00000006; font-size:12px }
.buy-info .drinkline{ display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px dashed #0002; border-radius:12px; background:#fff8 }
.buy-info .drinkline .emoji{ font-size:20px }

/* Dock-knapp */
.control-dock{ position:fixed; left:16px; bottom:16px; width:58px; height:58px; border-radius:50%; border:none; background:rgba(255,255,255,.92); box-shadow:var(--shadow); font-size:26px; cursor:pointer; display:none; z-index:25 }
.control-dock.show{ display:block }

/* Form/knappar */
.btn{ cursor:pointer; border:1px solid #0002; border-radius:14px; padding:.8rem 1rem; background:#fff; font-weight:800 }
.btn:hover{ filter:brightness(.98) }
.btn-primary{ background:var(--primary); border-color:var(--primary); color:#fff }
.btn-success{ background:var(--success); border-color:var(--success); color:#fff }
.input{ width:100%; padding:.8rem 1rem; border:2px solid #eef; border-radius:14px; background:#fff; outline:none; font-size:16px }
.input:focus{ border-color:var(--primary); box-shadow:0 0 0 4px rgba(74,125,246,.12) }
.input-lg{ font-size:18px; padding:1rem 1.1rem }
.form-row{ display:flex; gap:10px; align-items:center; margin-bottom:10px }
.form-row label{ min-width:110px; font-weight:600 }
.inline{ display:flex; gap:10px; align-items:center }
.hint{ margin:.25rem 0 0; color:var(--muted); font-size:12px }
.players{ display:flex; flex-direction:column; gap:10px; margin-top:8px }
.player-row{ display:flex; gap:10px; align-items:center; justify-content:space-between; background:#fafafa; border:1px solid #0001; padding:10px; border-radius:12px }
.player-info{ display:flex; gap:10px; align-items:center }
.dot{ width:18px; height:18px; border-radius:50%; border:2px solid #0006; display:inline-block }
.player-info .dot{ border:none; width:56px; height:56px }
.player-info .dot img{ width:100%; height:100%; object-fit:contain; border-radius:50% }
.remove-btn{ background:#fff; border:1px solid #0002; border-radius:12px; padding:.4rem .6rem }
.palette{ display:flex; flex-wrap:wrap; gap:12px }
.swatch{ width:84px; height:84px; border-radius:14px; box-shadow:0 0 0 2px #fff, 0 0 0 3px rgba(0,0,0,.15); cursor:pointer; position:relative; display:grid; place-items:center; background:#fff }
.swatch img{ width:92%; height:92%; object-fit:contain; border-radius:12px }
.swatch.selected::after{ content:"✓"; position:absolute; right:6px; bottom:6px; width:20px; height:20px; border-radius:50%; background:rgba(0,0,0,.75); color:#fff; display:grid; place-items:center; font-weight:900; font-size:12px }
.swatch[disabled]{ opacity:.35; cursor:not-allowed }

/* Turn toast */
.toast{ width:min(560px,92vw); background:rgba(255,255,255,.97); backdrop-filter:blur(8px); border-radius:20px; box-shadow:0 18px 48px rgba(0,0,0,.22); padding:18px 20px; transform:translateY(12px) scale(.97); opacity:0 }
.toast .toast-body{ display:flex; align-items:center; justify-content:center; gap:14px; font-weight:800; font-size:clamp(18px,3.2vw,28px) }
.toast .avatar{ width:44px; height:44px; border-radius:50%; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.25) }
.toast .avatar img{ width:100%; height:100%; object-fit:cover; display:block }
@keyframes toastIn{ from{opacity:0; transform:translateY(18px) scale(.94)} to{opacity:1; transform:none} }
@keyframes toastOut{ to{opacity:0; transform:translateY(8px) scale(.98)} }
.overlay.open .toast{ animation:toastIn .42s var(--ease) both }
.overlay.closing .toast{ animation:toastOut .32s ease both }

/* Zoom & wallet */
.zoom-ctrl{ position:fixed; right:16px; bottom:160px; display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius:14px; background:rgba(255,255,255,.9); backdrop-filter:blur(6px); box-shadow:var(--shadow); z-index:30 }
.zoom-ctrl label{ font-size:12px; font-weight:800; color:#333 }
.zoom-ctrl input[type="range"]{ width:140px }
.wallet-btn{ position:fixed; right:16px; bottom:84px; width:64px; height:64px; border:none; border-radius:50%; background:#fff; font-size:30px; line-height:1; display:grid; place-items:center; box-shadow:var(--shadow); cursor:pointer; z-index:30 }
.wallet-btn:hover{ filter:brightness(.98) }
.wallet-btn:active{ transform:translateY(1px) }

/* Helpers */
.hidden{ display:none !important }
#roll{ display:none !important }

/* Setup-pills */
#setup-overlay .modal-header .mode-toggle{ margin-left:auto; gap:10px }
#setup-overlay .mode-pill{
  background:#f2f3ff; color:#2b2f75; border:1px solid rgba(0,0,0,.06);
  border-radius:999px; padding:.55rem 1rem; font-weight:800; position:relative;
}
#setup-overlay .mode-pill.active{ background:var(--primary); color:#fff; box-shadow:0 6px 16px rgba(74,125,246,.35) }
#setup-overlay .add-player{ align-items:start; row-gap:18px }
#setup-overlay #color-palette{ margin-top:6px; margin-bottom:12px }
#setup-overlay #addP{ margin-top:4px }
/* Dölj sessiondelen tills vidare */
#session-controls{ display:none !important }
/* Badge på Session-pillret */
#mode-session::after{
  content:"FUNKTION INTE TILLGÄNGLIG ÄN";
  position:absolute; left:50%; top:100%; transform:translate(-50%,6px);
  white-space:nowrap; font-size:10px; font-weight:900; letter-spacing:.2px;
  color:#b04343; background:#ffe6e6; border:1px solid #f2bcbc;
  border-radius:999px; padding:.22rem .5rem; box-shadow:0 6px 14px rgba(176,67,67,.12);
}

/* Rules overlay skrollbart */
#rules-overlay .modal{ width:min(760px,94vw); max-height:92vh; overflow:auto; border-radius:22px }
#rules-overlay .modal .modal-body{ padding:16px 18px }
.rules-body .rules-table{ width:100%; border-collapse:collapse; margin:.4rem 0 1rem; background:#fff; border:1px solid #0001; border-radius:10px; overflow:hidden }
.rules-body .rules-table th,.rules-body .rules-table td{ padding:.55rem .7rem; border-bottom:1px solid #00000010 }
.rules-body .rules-table thead th{ background:#f7f7fb; text-align:left; font-weight:800 }
.rules-body .rules-table tbody tr:last-child td{ border-bottom:none }
.rules-body hr{ border:0; height:1px; background:#00000014; margin:12px 0 }
/* =======================
   MOBIL & RESPONSIVE FIXES
   ======================= */

/* ---- Bas-variabler för FAB-stapel ---- */
:root{
  --fab-size: 62px;               /* diameter på FABs */
  --fab-gap:  18px;               /* vertikalt mellanrum */
  --fab-right-por: clamp(28px, 7vw, 44px);  /* hur långt ut till höger i PORTRÄTT */
  --fab-right-land: clamp(60px, 10vw, 100px); /* hur långt ut till höger i LANDSKAP */
}

/* ==============================
   Gemensamma småskärmsanpassningar
   ============================== */
@media (max-width:560px), (max-height:520px){
  /* Centrala element */
  .center-box .logo{ width:clamp(150px,50vw,220px); }
  .center-core .tagline{
    max-width:clamp(150px,50vw,220px);
    font-size:11.5px; margin:-8px 0 -2px;
  }
  .center-row{ gap:8px; }

  /* Misärhög + enhetsruta */
  .cards-pile{ width:clamp(50px,14vw,76px); }
  .units-panel{ min-width:120px; padding:6px 8px; }
  .unit{ gap:6px; font-size:11px; }
  .unit .u-ico{ font-size:15px; width:16px; }

  /* Pjäser & slots */
  :root{ --piece-size:24px; }
  .spot .slot{ width:30px; height:28px; }
  .owner-badge{ width:18px; height:18px; top:4px; right:4px; }

  /* Rutor/etiketter */
  .tile .icon{ font-size:12px; }
  .tile .name{ font-size:8px; }
  .tile .price,.tile small{ font-size:6.8px; }
  .corner .name{ font-size:10px; }

  .edge-label.e-left  { left:3.6%; font-size:clamp(15px,5.6vw,30px); }
  .edge-label.e-right { right:3.6%; font-size:clamp(15px,5.6vw,30px); }
  .edge-label.e-top   { top:.4%;   font-size:clamp(16px,5.2vw,30px); }
  .edge-label.e-bottom{ bottom:.4%;font-size:clamp(16px,5.4vw,30px); }

  /* Tärningar/modals mindre */
  .die3d{ width:68px; height:68px; }
  .pip{ width:9px; height:9px; }
  .control-modal{ width:min(94vw,620px); }

  /* Dölj zoom på mobil */
  .zoom-ctrl{ display:none !important; }
}

/* Extra tight för pytte-skärmar */
@media (max-width:380px){
  .center-box .logo{ width:clamp(140px,58vw,190px); }
  .center-core .tagline{ font-size:10.5px; }
  .cards-pile{ width:clamp(46px,16vw,66px); }
  .units-panel{ min-width:112px; }
  :root{ --piece-size:22px;--fab-inset: 36px; --fab-size: 54px; }
  .tile .name{ font-size:7.5px; }
  .tile .price,.tile small{ font-size:6.2px; }
  
}

/* Setup-overlay: mindre & scroll på mobil */
@media (max-width:560px){
  #setup-overlay .modal{
    width:92vw; max-height:86vh; overflow:auto;
  }
  #setup-overlay .modal-header{ position:sticky; top:0; z-index:1; }
}

/* ===========================
   FAB-KNAPPAR: fast stapel höger
   =========================== */

/* Gemensamt för alla mindre enheter – samma storlek/z-index */
@media (max-width:900px){
  .wallet-btn, .fab, .control-dock{
    position:fixed;
    width:var(--fab-size); height:var(--fab-size);
    left:auto; z-index:50;
    box-shadow:0 10px 28px rgba(0,0,0,.22);
    transition:transform .2s ease;
  }
  @media (hover:hover){
    .wallet-btn:hover, .fab:hover, .control-dock:hover{ transform:scale(1.06); }
  }
}

/* PORTRÄTT – stapla från botten: 💰 längst ner, 📖 ovanför, 🎲 överst */
@media (max-width:560px) and (orientation:portrait){
  .wallet-btn{ right:var(--fab-right-por);
    bottom:calc(env(safe-area-inset-bottom) + 20px); }
  .fab{ right:var(--fab-right-por);
    bottom:calc(env(safe-area-inset-bottom) + 20px + var(--fab-size) + var(--fab-gap)); }
  .control-dock{ right:var(--fab-right-por);
    bottom:calc(env(safe-area-inset-bottom) + 20px + 2*(var(--fab-size) + var(--fab-gap))); }
}

@media (max-width:900px) and (orientation:landscape){
  .wallet-btn{
    right: calc(var(--fab-right-land) + var(--fab-inset));
    bottom: 6vh;
  }
  .fab{
    right: calc(var(--fab-right-land) + var(--fab-inset));
    bottom: calc(6vh + var(--fab-size) + var(--fab-gap));
  }
  .control-dock{
    right: calc(var(--fab-right-land) + var(--fab-inset));
    bottom: calc(6vh + 2*(var(--fab-size) + var(--fab-gap)));
  }
}

/* Mobil-hint */
.mobile-hint{
  position:fixed; left:16px; bottom:170px;
  padding:.65rem .8rem; border-radius:14px;
  background:rgba(255,255,255,.96);
  box-shadow:0 10px 26px rgba(0,0,0,.18);
  border:1px solid #0001; font-weight:800; z-index:28; font-size:13px;
}
.mobile-hint.hidden{ display:none !important; }
@media (orientation:landscape){ .mobile-hint{ display:none; } }
@media (min-width:561px){ .mobile-hint{ display:none; } }

/* Dölj FABs/zoom när setup-overlay är öppen */
#setup-overlay.open ~ #open-wallet,
#setup-overlay.open ~ #control-dock,
#setup-overlay.open ~ #open-rules,
#setup-overlay.open ~ .zoom-ctrl{
  display: none !important;
}
