/* ===== ALDENHAM GOLF - COMPLETE CSS REWRITE ===== */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@700;800&family=Inter:wght@400;600;700&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --green-dark:   #0b1f10;
    --green-mid:    #163a1e;
    --green-bright: #2d8c44;
    --gold:         #d4a017;
    --gold-light:   #f0c040;
    --sand:         #e2cfaa;
    --water:        #1e6eb0;
    --text:         #f0ede8;
    --text-muted:   #a0a898;
    --glass-bg:     rgba(10,25,14,0.82);
    --glass-border: rgba(255,255,255,0.1);
    --radius:       12px;
    --shadow:       0 8px 32px rgba(0,0,0,0.6);
}

html, body { width:100%; height:100%; overflow:hidden; font-family:'Inter',sans-serif; background:var(--green-dark); color:var(--text); }

/* SCREENS */
.screen { position:fixed; inset:0; display:none; z-index:10; }
.screen.active { display:flex; align-items:center; justify-content:center; }
#screen-play.active { flex-direction:column; align-items:stretch; justify-content:flex-start; }
#screen-scorecard { z-index:50; background:rgba(0,0,0,0.82); }
.hidden { display:none !important; }

/* ====== MENU SCREEN ====== */
.menu-card {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 20px;
    padding: 40px 36px;
    width: 420px;
    text-align: center;
    box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,0.05);
    backdrop-filter: blur(20px);
}
.crest { font-size: 3.5rem; margin-bottom: 10px; filter: drop-shadow(0 0 20px rgba(212,160,23,0.6)); animation: float 3s ease-in-out infinite; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

h1 { font-family:'Cinzel',serif; font-size:2.2rem; font-weight:800; letter-spacing:.4em; background:linear-gradient(135deg,var(--gold),var(--gold-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.subtitle { font-family:'Cinzel',serif; font-size:.8rem; letter-spacing:.4em; color:var(--gold); opacity:.8; margin-bottom:6px; }
.desc { color:var(--text-muted); font-size:.85rem; margin-bottom:28px; }

.field { text-align:left; margin-bottom:20px; }
.field label { display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--gold); font-weight:700; margin-bottom:8px; }
.field input[type=text] { width:100%; background:rgba(0,0,0,0.4); border:1px solid var(--glass-border); border-radius:8px; padding:11px 14px; color:var(--text); font-size:1rem; font-family:'Inter',sans-serif; transition:border-color .2s; }
.field input:focus { outline:none; border-color:var(--gold); }

.tee-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.tee-btn { display:flex; align-items:center; gap:10px; padding:10px 14px; background:rgba(0,0,0,0.35); border:1.5px solid var(--glass-border); border-radius:9px; cursor:pointer; transition:all .2s; font-size:.85rem; }
.tee-btn:hover { background:rgba(255,255,255,0.06); }
.tee-btn.active { border-color:var(--gold); background:rgba(212,160,23,0.1); }
.dot { width:13px; height:13px; border-radius:50%; flex-shrink:0; border:2px solid rgba(255,255,255,0.5); }
.yellow-dot { background:#f0c040; } .red-dot { background:#e33; } .green-dot { background:#3c3; } .blue-dot { background:#38f; }

.btn-start { width:100%; margin-top:22px; background:linear-gradient(135deg,var(--gold) 0%,#a87010 100%); border:none; border-radius:10px; padding:15px; color:#0b1f10; font-family:'Cinzel',serif; font-size:1rem; font-weight:700; letter-spacing:.1em; cursor:pointer; transition:all .25s; box-shadow:0 4px 20px rgba(212,160,23,0.35); }
.btn-start:hover { transform:translateY(-2px); box-shadow:0 6px 28px rgba(212,160,23,0.55); }

/* ====== HOLE INTRO ====== */
#intro-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; }
.intro-card { position: relative; z-index: 2; background: rgba(10, 25, 14, 0.75); border: 1px solid var(--glass-border); border-radius: 20px; padding: 44px; width: 420px; text-align: center; box-shadow: var(--shadow); backdrop-filter: blur(12px); border-top: 3px solid var(--gold); }
.intro-hole-label { font-family:'Cinzel',serif; font-size:.8rem; letter-spacing:.35em; color:var(--gold); text-transform:uppercase; margin-bottom:8px; }
.intro-card h2 { font-family:'Cinzel',serif; font-size:1.7rem; color:var(--text); margin-bottom:22px; }
.intro-stats { display:flex; justify-content:center; gap:30px; margin-bottom:20px; }
.istat { display:flex; flex-direction:column; align-items:center; background:rgba(0,0,0,0.3); border-radius:10px; padding:12px 18px; border:1px solid var(--glass-border); }
.istat-label { font-size:.65rem; letter-spacing:.15em; color:var(--gold); font-weight:700; text-transform:uppercase; }
.istat-val { font-family:'Cinzel',serif; font-size:1.8rem; font-weight:700; color:var(--text); margin-top:2px; }
.intro-desc { color:var(--text-muted); font-size:.9rem; margin-bottom:4px; }

/* ====== PLAY SCREEN ====== */
.top-bar { height:56px; background:var(--glass-bg); border-bottom:1px solid var(--glass-border); display:flex; align-items:center; gap:16px; padding:0 16px; flex-shrink:0; backdrop-filter:blur(16px); z-index:10; }
.hole-badge { background:var(--gold); color:#0b1f10; font-weight:800; font-size:.8rem; padding:3px 9px; border-radius:20px; font-family:'Cinzel',serif; }
#hud-hole-name-short { font-size:.85rem; color:var(--text-muted); max-width:120px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.tb-stats { display:flex; gap:14px; flex:1; justify-content:center; }
.tbstat { display:flex; flex-direction:column; align-items:center; font-size:.72rem; color:var(--text-muted); }
.tbstat strong { font-size:.95rem; color:var(--text); font-weight:700; }
.tb-right { display:flex; align-items:center; gap:10px; }
.wind-display { display:flex; flex-direction:column; align-items:center; font-size:.72rem; color:var(--text-muted); min-width:38px; }
.wind-arrow { font-size:1.1rem; color:var(--gold); transition:transform .5s; display:inline-block; }
.btn-sc { background:rgba(255,255,255,0.08); border:1px solid var(--glass-border); border-radius:6px; color:var(--text); padding:5px 10px; cursor:pointer; font-size:.78rem; transition:background .2s; }
.btn-sc:hover { background:rgba(255,255,255,0.15); }
.btn-quit { background:transparent; border:1px solid rgba(255,50,50,0.25); border-radius:6px; color:#ff5555; padding:5px 9px; cursor:pointer; font-size:.85rem; transition:all .2s; }
.btn-quit:hover { background:rgba(255,50,50,0.15); }

#canvas-wrap { flex:1; position:relative; overflow:hidden; cursor:crosshair; }
#game-canvas { display:block; width:100%; height:100%; }

/* Hint bubble */
#hint-box { position:absolute; bottom:16px; left:50%; transform:translateX(-50%); background:rgba(0,0,0,0.78); border:1px solid var(--gold); border-radius:24px; padding:10px 20px; font-size:.85rem; font-weight:600; color:var(--gold); white-space:nowrap; pointer-events:none; animation:hintBounce 2.2s ease-in-out infinite; }
@keyframes hintBounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(-7px)} }

/* Shot pop */
#shot-pop { position:absolute; top:18px; left:50%; transform:translateX(-50%); background:rgba(0,0,0,0.88); border:2px solid var(--gold); border-radius:14px; padding:14px 28px; text-align:center; z-index:20; animation:popIn .3s cubic-bezier(.17,.89,.32,1.27); }
@keyframes popIn { from{opacity:0;transform:translateX(-50%) scale(.7)} to{opacity:1;transform:translateX(-50%) scale(1)} }
#shot-pop-title { font-family:'Cinzel',serif; font-size:1.3rem; font-weight:700; color:var(--gold); }
#shot-pop-sub { font-size:.9rem; color:var(--text); margin-top:4px; }

/* Bottom Club Bar */
.bottom-bar { height:64px; background:var(--glass-bg); border-top:1px solid var(--glass-border); display:flex; align-items:center; gap:10px; padding:0 16px; flex-shrink:0; backdrop-filter:blur(16px); }
.club-cycle-btn { background:rgba(255,255,255,0.07); border:1px solid var(--glass-border); border-radius:8px; color:var(--text); width:34px; height:34px; cursor:pointer; font-size:1rem; transition:background .2s; }
.club-cycle-btn:hover { background:rgba(255,255,255,0.15); }
.club-info { display:flex; flex-direction:column; align-items:center; min-width:100px; }
.club-name { font-weight:700; font-size:1rem; color:var(--gold); }
.club-range { font-size:.72rem; color:var(--text-muted); }

.power-wrap { display:flex; align-items:center; gap:8px; flex:1; margin-left:10px; }
.power-label { font-size:.65rem; font-weight:700; letter-spacing:.12em; color:var(--gold); text-transform:uppercase; white-space:nowrap; }
.power-bar-bg { flex:1; height:14px; background:rgba(0,0,0,0.5); border-radius:8px; border:1px solid var(--glass-border); overflow:hidden; }
.power-bar-fill { height:100%; width:0%; background:linear-gradient(90deg,#2d8c44,#f0c040,#e33); border-radius:8px; transition:width .05s linear; }
.power-pct { font-size:.8rem; font-weight:700; min-width:34px; color:var(--text); }

/* ====== SCORECARD MODAL ====== */
.scorecard-screen { /* handled by .screen + .active now */ }
.sc-card { background:rgba(8,20,12,0.97); border:1px solid var(--glass-border); border-radius:16px; padding:28px; max-width:700px; width:95%; max-height:90vh; overflow-y:auto; backdrop-filter:blur(20px); }
.sc-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; border-bottom:1px solid var(--glass-border); padding-bottom:10px; }
.sc-header h2 { font-family:'Cinzel',serif; color:var(--gold); font-size:1.3rem; }
.sc-header button { background:none; border:none; color:var(--text-muted); font-size:1.4rem; cursor:pointer; }
.sc-table-wrap { overflow-x:auto; }
#sc-table { width:100%; border-collapse:collapse; font-size:.8rem; text-align:center; }
#sc-table th, #sc-table td { padding:7px 10px; border:1px solid rgba(255,255,255,0.07); }
#sc-table th { background:rgba(0,0,0,0.3); color:var(--gold); font-weight:700; }
.score-row td { font-weight:700; font-size:.9rem; }
.score-row td.birdie { color:#4cd964; }
.score-row td.bogey { color:#ff5555; }
.score-row td.par-score { color:var(--text); }
.sc-totals { margin-top:16px; font-size:.9rem; color:var(--text-muted); text-align:right; }

/* ====== FINISH ====== */
.finish-card { background:var(--glass-bg); border:1px solid rgba(212,160,23,0.3); border-radius:20px; padding:40px; width:400px; text-align:center; box-shadow:var(--shadow); backdrop-filter:blur(20px); }
.finish-card h1 { font-family:'Cinzel',serif; color:var(--gold); font-size:1.8rem; margin-bottom:6px; }
#finish-name { color:var(--text-muted); margin-bottom:20px; }
.finish-stats { display:flex; justify-content:center; gap:30px; margin-bottom:24px; }
.fstat { display:flex; flex-direction:column; align-items:center; background:rgba(0,0,0,0.3); border-radius:10px; padding:14px 24px; }
.fstat span { font-size:.7rem; letter-spacing:.1em; color:var(--gold); text-transform:uppercase; }
.fstat strong { font-family:'Cinzel',serif; font-size:2rem; color:var(--text); }
.finish-sc { font-size:.78rem; color:var(--text-muted); margin-bottom:4px; max-height:120px; overflow:auto; }

/* Dynamic additions */
.mode-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.mode-btn { display:flex; align-items:center; justify-content:center; padding:10px 14px; background:rgba(0,0,0,0.35); border:1.5px solid var(--glass-border); border-radius:9px; cursor:pointer; transition:all .2s; font-size:.85rem; text-align:center; }
.mode-btn:hover { background:rgba(255,255,255,0.06); }
.mode-btn.active { border-color:var(--gold); background:rgba(212,160,23,0.1); }

.btn-swing {
    height: 42px;
    padding: 0 24px;
    background: linear-gradient(135deg, var(--gold) 0%, #a87010 100%);
    border: none;
    border-radius: 8px;
    color: #0b1f10;
    font-weight: 700;
    font-size: 0.9rem;
    letter-spacing: 0.05em;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(212, 160, 23, 0.3);
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 6px;
    user-select: none;
    touch-action: manipulation;
}
.btn-swing:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(212, 160, 23, 0.5);
}
.btn-swing:active {
    transform: translateY(1px);
    box-shadow: 0 2px 8px rgba(212, 160, 23, 0.2);
}
.btn-swing.charging {
    background: linear-gradient(135deg, #e33 0%, #a01010 100%);
    box-shadow: 0 4px 18px rgba(220, 50, 50, 0.6);
    animation: swingPulse 0.5s ease-in-out infinite alternate;
}
@keyframes swingPulse {
    from { transform: scale(1); }
    to   { transform: scale(1.05); box-shadow: 0 6px 24px rgba(220,50,50,0.8); }
}

#ball-pointer {
    position: absolute;
    background: rgba(10, 25, 14, 0.9);
    border: 1.5px solid var(--gold);
    color: var(--gold);
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    box-shadow: var(--shadow);
    pointer-events: none;
    z-index: 100;
    transform: translate(-50%, -50%);
    white-space: nowrap;
}

.finish-sc table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.75rem;
    margin-top: 10px;
}
.finish-sc th, .finish-sc td {
    padding: 6px 8px;
    border: 1px solid rgba(255,255,255,0.06);
    text-align: center;
}
.finish-sc th {
    background: rgba(0,0,0,0.25);
    color: var(--gold);
}
.finish-sc tr.highlight-row td {
    font-weight: 700;
    background: rgba(255,255,255,0.03);
}

/* ====== MOBILE RESPONSIVENESS ====== */
@media (max-width: 600px) {
    .menu-card, .intro-card, .finish-card {
        width: 92%;
        padding: 24px 20px;
    }
    .crest { font-size: 2.5rem; }
    h1 { font-size: 1.7rem; }
    .intro-stats { gap: 12px; }
    .istat { padding: 6px 10px; }
    .istat-val { font-size: 1.3rem; }
    
    .top-bar {
        height: auto;
        padding: 6px 10px;
        flex-wrap: wrap;
        gap: 6px 10px;
    }
    #hud-hole-name-short {
        display: none;
    }
    .tb-stats {
        width: 100%;
        order: 3;
        justify-content: space-around;
        border-top: 1px solid var(--glass-border);
        padding-top: 6px;
        margin-top: 2px;
        gap: 8px;
    }
    .tbstat {
        flex-direction: row;
        gap: 4px;
        font-size: 0.7rem;
    }
    .tbstat strong {
        font-size: 0.85rem;
    }
    
    .bottom-bar {
        height: auto;
        min-height: 96px;
        display: grid;
        grid-template-areas: 
            "prev info next swing"
            "power power power power";
        grid-template-columns: auto 1fr auto auto;
        gap: 10px 8px;
        padding: 10px 12px;
    }
    
    #club-prev { grid-area: prev; }
    .club-info { grid-area: info; min-width: 80px; }
    #club-next { grid-area: next; }
    .power-wrap { grid-area: power; margin-left: 0; width: 100%; }
    #btn-swing { grid-area: swing; height: 36px; padding: 0 16px; font-size: 0.85rem; }
    
    /* Optimize scaling for smaller canvas view */
    #canvas-wrap {
        border-bottom: 1px solid var(--glass-border);
    }
}

