/* Dad's Zany-Style Golf - retro Amiga-ish UI */
:root{
  --grass:#2f8f3a; --grass-dk:#247030; --grass-lt:#41a64a;
  --brick:#a8502b; --brick-dk:#6d3017; --brick-top:#cf7b4d; --mortar:#52230f;
  --ink:#0b1a0c; --paper:#f4ead3; --gold:#ffd34d; --red:#e23b2e;
}
*{box-sizing:border-box;}
[hidden]{display:none !important;}
html,body{margin:0;height:100%;}
body{
  background:var(--grass-dk);
  background-image:
    repeating-linear-gradient(0deg, rgba(0,0,0,.06) 0 2px, transparent 2px 6px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 2px, transparent 2px 8px);
  color:#fff;
  font-family:'Press Start 2P', 'Courier New', monospace;
  -webkit-font-smoothing:none;
  display:flex; align-items:center; justify-content:center;
  min-height:100%;
  padding:16px;
}
#app{width:100%; max-width:1000px;}
.screen{display:flex; flex-direction:column; align-items:center;}

/* ---- brick-bordered panels ---- */
.panel{
  background:var(--grass);
  border:8px solid var(--brick);
  box-shadow:0 0 0 4px var(--mortar), inset 0 0 0 3px var(--brick-top),
             0 14px 0 rgba(0,0,0,.35);
  border-radius:6px;
  padding:30px 28px;
  text-align:center;
  max-width:560px; width:100%;
}
.panel.wide{max-width:680px;}

.logo{
  font-size:30px; line-height:1.25; margin:0 0 6px;
  color:var(--gold);
  text-shadow:3px 3px 0 var(--brick-dk), 6px 6px 0 rgba(0,0,0,.35);
  letter-spacing:1px;
}
.logo span{color:var(--red);}
.logo.small{font-size:18px; margin-bottom:18px;}
.tagline{font-size:9px; color:#fff; opacity:.85; margin:0 0 24px;}

.field{margin:14px 0; text-align:left;}
.field label{display:block; font-size:9px; margin-bottom:8px; opacity:.85;}
input[type=password]{
  width:100%; padding:12px; font-family:inherit; font-size:14px;
  background:var(--ink); color:var(--gold); border:3px solid var(--brick-top);
  border-radius:4px; outline:none;
}

.btn{
  font-family:inherit; font-size:12px; cursor:pointer;
  background:var(--gold); color:var(--brick-dk);
  border:none; border-radius:4px; padding:14px 22px;
  box-shadow:0 5px 0 #b8932f, 0 6px 0 rgba(0,0,0,.3);
  transition:transform .05s, box-shadow .05s;
  margin-top:10px;
}
.btn:active{transform:translateY(4px); box-shadow:0 1px 0 #b8932f;}
.btn.big{font-size:15px; padding:16px 30px; margin-top:24px;}
.btn.large{width:100%;}

.err{color:#ffd34d; font-size:9px; min-height:12px; margin-top:14px;}

.sect{font-size:11px; margin:20px 0 12px; color:#fff; opacity:.9;}
.row{display:flex; gap:14px; justify-content:center; flex-wrap:wrap;}
.card{
  flex:1 1 0; min-width:150px;
  font-family:inherit; font-size:11px; cursor:pointer;
  background:var(--grass-dk); color:#fff;
  border:4px solid var(--brick-dk); border-radius:5px;
  padding:18px 12px; line-height:1.5;
  transition:transform .05s;
}
.card:active{transform:translateY(2px);}
.card.active{
  background:var(--brick); border-color:var(--gold);
  box-shadow:0 0 0 2px var(--gold);
}
.card.locked{opacity:.6; cursor:not-allowed;}
.card .tag{
  display:inline-block; background:var(--gold); color:var(--brick-dk);
  font-size:8px; padding:3px 6px; border-radius:3px; margin-left:6px;
}
.note{font-size:8px; line-height:1.7; opacity:.8; margin:12px 4px 0; min-height:24px;}

/* ---- game screen ---- */
#hud{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  width:100%; max-width:960px; margin-top:10px;
  font-size:9px; color:var(--gold);
  background:#15240f;
  border:4px solid var(--brick-dk); border-radius:5px;
  box-shadow:inset 0 0 0 2px #0b1709;
  padding:9px 12px;
}
#hud .spacer{flex:1;}
#hud-name{color:#fff; opacity:.9;}
#hud .cnt{background:#0b1709; color:var(--gold); padding:4px 8px; border-radius:3px;}
.mode-pill{background:var(--gold); color:var(--brick-dk); padding:4px 8px; border-radius:3px;}
.mini{
  font-family:inherit; font-size:8px; cursor:pointer;
  background:var(--grass-dk); color:#fff; border:3px solid var(--brick-dk);
  border-radius:4px; padding:8px 10px;
}
.mini:active{transform:translateY(2px);}

#stage{position:relative; width:100%; max-width:960px;}
#cv{
  width:100%; height:auto; display:block;
  image-rendering:pixelated; image-rendering:crisp-edges;
  background:var(--ink);
  border:8px solid var(--brick);
  box-shadow:0 0 0 4px var(--mortar), 0 14px 0 rgba(0,0,0,.35);
  border-radius:6px;
  touch-action:none;
}
.overlay{
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  background:rgba(11,26,12,.82);
  border-radius:6px; text-align:center; padding:20px;
}
.overlay .big{font-size:20px; color:var(--gold); margin-bottom:10px;
  text-shadow:2px 2px 0 var(--brick-dk);}
.overlay div{font-size:11px; line-height:1.6;}
.overlay .sub{font-size:9px; opacity:.85; margin-top:8px;}
.hint{font-size:9px; opacity:.8; margin:12px 4px 0; max-width:960px; line-height:1.7;}
