/* Patolli — Aztec Game of Chance. Themed to ancientgames.org palette. */
.patolli-wrap{
    --pat-primary:#8B4513;--pat-secondary:#C19A6B;--pat-accent:#B8860B;
    --pat-bg:#FDF8F0;--pat-ink:#2C1810;--pat-panel:#F5EDE0;--pat-line:#D4C4A8;
    --pat-red:#C0392B;--pat-blue:#2C6E9B;
    max-width:640px;margin:2rem auto;
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    color:var(--pat-ink);
}
.patolli-wrap *{box-sizing:border-box}

.patolli-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.5rem}
.patolli-mode{display:inline-flex;border:2px solid var(--pat-secondary);border-radius:999px;overflow:hidden}
.pat-mode-btn{background:var(--pat-panel);color:var(--pat-primary);border:none;padding:.45rem 1rem;font-weight:600;cursor:pointer;font-size:.85rem;line-height:1}
.pat-mode-btn.is-active{background:var(--pat-primary);color:#fff}
.pat-sound-btn{background:var(--pat-panel);border:2px solid var(--pat-secondary);border-radius:50%;width:2.4rem;height:2.4rem;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center}
.pat-sound-btn .pat-sound-on{display:none}
.pat-sound-btn[aria-pressed="true"] .pat-sound-on{display:inline}
.pat-sound-btn[aria-pressed="true"] .pat-sound-off{display:none}

.patolli-status{text-align:center;font-size:1.05rem;font-weight:600;color:var(--pat-primary);min-height:1.5em;margin:.25rem 0 .75rem}

.patolli-board-shell{position:relative;width:100%}
.patolli-canvas{
    display:block;width:100%;max-width:600px;margin:0 auto;aspect-ratio:1/1;
    background:radial-gradient(circle at 50% 45%,#F7EFE1 0%,#EADCC4 100%);
    border:3px solid var(--pat-primary);border-radius:12px;
    box-shadow:0 6px 20px rgba(44,24,16,.18);cursor:pointer;touch-action:manipulation;
}

.patolli-winmodal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(44,24,16,.55);border-radius:12px;animation:pat-fade .3s ease}
.patolli-winmodal[hidden]{display:none}
@keyframes pat-fade{from{opacity:0}to{opacity:1}}
.patolli-winmodal-card{background:var(--pat-bg);border:3px solid var(--pat-accent);border-radius:12px;padding:1.5rem 1.75rem;text-align:center;max-width:80%;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.patolli-win-title{margin:.2rem 0 .4rem;color:var(--pat-primary);font-size:1.4rem}
.patolli-win-sub{margin:0 0 1rem;font-size:.95rem;color:var(--pat-ink)}

.patolli-hud{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin:1rem 0 .5rem;flex-wrap:wrap}
.pat-player{display:flex;align-items:center;gap:.4rem;font-size:.85rem;flex:1;min-width:130px}
.pat-player-2{justify-content:flex-end;text-align:right}
.pat-dot{width:.85rem;height:.85rem;border-radius:50%;flex:0 0 auto;border:2px solid rgba(0,0,0,.25)}
.pat-player-1 .pat-dot{background:var(--pat-red)}
.pat-player-2 .pat-dot{background:var(--pat-blue)}
.pat-player.is-turn{font-weight:700}
.pat-player.is-turn .pat-name::after{content:" ●";color:var(--pat-accent)}
.pat-name{font-weight:600}

.pat-beans{display:flex;gap:.3rem;flex:0 0 auto}
.pat-bean{width:1.15rem;height:1.6rem;border-radius:45%/35%;background:linear-gradient(135deg,#3a2a1a,#1d130a);border:1px solid #0c0805;position:relative;transition:transform .15s ease}
.pat-bean.is-marked::after{content:"";position:absolute;top:50%;left:50%;width:.42rem;height:.42rem;background:#F5EDE0;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 2px rgba(0,0,0,.4)}
.pat-bean.is-rolling{animation:pat-shake .3s ease}
@keyframes pat-shake{0%,100%{transform:translateY(0) rotate(0)}25%{transform:translateY(-6px) rotate(-12deg)}75%{transform:translateY(-3px) rotate(10deg)}}

.patolli-controls{display:flex;gap:.6rem;justify-content:center;margin:.75rem 0}
.pat-roll-btn,.pat-new-btn,.pat-again-btn{border:none;border-radius:6px;font-weight:700;cursor:pointer;font-size:1rem;padding:.7rem 1.6rem}
.pat-roll-btn,.pat-again-btn{background:var(--pat-accent);color:#fff}
.pat-roll-btn:hover,.pat-again-btn:hover{background:#a6790a}
.pat-roll-btn:disabled{background:var(--pat-secondary);cursor:default;opacity:.7}
.pat-new-btn{background:var(--pat-primary);color:#fff}
.pat-new-btn:hover{background:#73380f}

.patolli-rules{margin-top:1rem;background:var(--pat-panel);border:1px solid var(--pat-line);border-radius:8px;padding:.4rem 1rem}
.patolli-rules summary{cursor:pointer;font-weight:700;color:var(--pat-primary);padding:.4rem 0}
.patolli-rules-body{font-size:.9rem;line-height:1.6;padding-bottom:.6rem}
.patolli-rules-body ul{margin:.4rem 0 .6rem;padding-left:1.2rem}
.patolli-disclaimer,.patolli-responsible{background:#fff;border-left:3px solid var(--pat-accent);padding:.5rem .75rem;border-radius:4px;font-size:.85rem}
.patolli-responsible{border-left-color:var(--pat-red)}

@media (max-width:480px){
    .patolli-wrap{margin:1.25rem auto}
    .patolli-status{font-size:.95rem}
    .pat-roll-btn,.pat-new-btn{padding:.7rem 1.1rem;font-size:.95rem}
    .pat-beans{order:3;width:100%;justify-content:center;margin-top:.3rem}
}
@media (prefers-reduced-motion:reduce){
    .pat-bean.is-rolling,.patolli-winmodal{animation:none}
    .pat-bean{transition:none}
}
/* Collapsible FAQ (shared style, matches casino pages) */
details.ag-faq{background:#fff;border:1px solid #d8cfc0;border-radius:6px;margin:0 0 10px;overflow:hidden}
details.ag-faq summary{cursor:pointer;list-style:none;padding:14px 44px 14px 18px;position:relative;font-weight:700;color:#2C1810;font-size:16px;line-height:1.4;user-select:none}
details.ag-faq summary h3,details.ag-faq summary .ag-faq-q{display:inline;margin:0;padding:0;border:0;font-family:inherit;font-size:inherit;font-weight:inherit;color:inherit;line-height:inherit}
details.ag-faq summary::-webkit-details-marker{display:none}
details.ag-faq summary::after{content:'+';position:absolute;right:16px;top:50%;transform:translateY(-50%);width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;font-weight:400;color:#B8860B;border:1px solid #C19A6B;border-radius:50%;transition:transform .2s ease}
details.ag-faq[open] summary::after{content:'\2212';transform:translateY(-50%)}
details.ag-faq summary:hover{background:#f5efe3}
details.ag-faq .ag-faq-body{padding:0 18px 14px;color:#2C1810;font-size:15px;line-height:1.6;border-top:1px solid #d8cfc0}
details.ag-faq .ag-faq-body p{margin:12px 0 0}
