:root{--bg:#0a0c12;--bg-elev:#12151d;--bg-surface:#181c26;--bg-elev-2:#1f242f;--fg:#f5f6f8;--fg-secondary:#c8ccd6;--muted:#8a92a3;--muted-2:#6b7485;--accent:#c5a26f;--accent-hover:#d4b484;--accent-subtle:rgba(197,162,111,0.12);--card-bg:#f8f6f1;--success:#0f3d2a;--success-border:#1e6b4a;--error:#3a1f23;--error-border:#5c2f35;--radius:12px;--radius-sm:8px;--border:rgba(255,255,255,0.06);--border-strong:rgba(255,255,255,0.10);--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-feature-settings:"tnum" 1;-webkit-font-smoothing:antialiased;min-height:100%;text-rendering:optimizeLegibility}a{color:var(--accent);text-decoration:none;transition:color .1s ease}a:hover{color:var(--accent-hover)}.container{max-width:1120px;margin:0 auto;padding:var(--space-4) var(--space-5) 4.5rem}h1{font-size:1.35rem;font-weight:700;letter-spacing:-.01em;margin:0 0 var(--space-1);color:var(--accent)}h2{font-size:1.15rem;font-weight:600;color:var(--fg);letter-spacing:-.005em}.subtitle,h2{margin:0 0 var(--space-3)}.subtitle{color:var(--muted);max-width:68ch;line-height:1.35;font-size:.85rem}.subtitle code{background:var(--bg-elev);padding:.1rem .35rem;border-radius:4px;font-size:.88em;color:var(--fg-secondary);border:1px solid var(--border)}.premium-surface{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 2px rgba(0,0,0,.2)}.site-nav{display:flex;justify-content:space-between;gap:var(--space-4);padding:.7rem var(--space-5);background:rgba(10,12,18,.92);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:100;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.brand,.site-nav{align-items:center}.brand{font-weight:700;color:var(--fg);text-decoration:none;display:inline-flex;gap:var(--space-2);font-size:1.02rem;letter-spacing:-.01em}.brand-pip{color:var(--accent);font-size:1.15em}.nav-links{display:flex;list-style:none;margin:0;padding:0;gap:.35rem;flex-wrap:wrap}.nav-link{color:var(--muted);text-decoration:none;padding:.4rem .7rem;border-radius:var(--radius-sm);font-size:.92rem;font-weight:500;transition:all .1s ease}.nav-link:hover{color:var(--fg-secondary);background:var(--bg-elev)}.nav-link-active{color:var(--fg);background:var(--accent-subtle);border:1px solid var(--accent)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:rgba(18,21,29,.96);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding-bottom:env(safe-area-inset-bottom,0)}.mobile-bottom-nav ul{display:flex;list-style:none;margin:0;padding:.35rem .25rem;justify-content:space-around}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:1px;font-size:.68rem;color:var(--muted);padding:.35rem .6rem;border-radius:8px;min-width:52px}.mobile-bottom-nav a.active{color:var(--accent)}.mobile-bottom-nav .nav-icon{font-size:1.1rem;line-height:1}.hero{text-align:center;padding:2.25rem 1rem 1.75rem;margin-bottom:var(--space-6)}.hero h1{font-size:clamp(2rem,5.5vw,2.65rem);margin-bottom:var(--space-3)}.hero .subtitle{margin:0 auto var(--space-6);max-width:52ch;font-size:1.02rem}.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:var(--space-4);gap:var(--space-4)}.tile{display:flex;flex-direction:column;gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5) var(--space-5) var(--space-4);color:var(--fg);text-decoration:none;transition:transform .15s cubic-bezier(.2,0,0,1),border-color .15s ease,box-shadow .15s ease;position:relative}.tile:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 8px 24px -12px rgba(0,0,0,.35)}.tile-title{margin:0;font-size:1.15rem;color:var(--accent);font-weight:600;letter-spacing:-.01em}.tile-blurb{margin:0;color:var(--muted);font-size:.93rem;line-height:1.45}.tile-arrow{align-self:flex-end;margin-top:auto;color:var(--accent);font-size:1.35rem;opacity:.75;transition:transform .15s ease}.tile:hover .tile-arrow{transform:translateX(2px);opacity:1}.chart{display:inline-block;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3)}.chart-title{margin:0 0 var(--space-2);font-size:.78rem;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.chart-table{border-collapse:separate;border-spacing:2px}.chart-col-head,.chart-corner,.chart-row-head{background:transparent;color:var(--muted-2);font-weight:600;font-size:.72rem;padding:0}.chart-cell,.chart-col-head,.chart-corner,.chart-row-head{width:var(--cell-size,34px);height:var(--cell-size,34px);text-align:center}.chart-cell{font-size:.7rem;font-weight:700;border-radius:5px;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;transition:transform .1s ease}@property --cell-ring-angle{syntax:"<angle>";initial-value:0deg;inherits:false}.chart-cell-highlight{z-index:3;box-shadow:inset 0 0 7px 1px rgba(255,240,200,.85),0 0 8px 1px rgba(255,210,120,.95),0 0 16px 3px rgba(201,139,255,.6);animation:cell-halo-pulse .9s ease-in-out infinite}.chart-cell-highlight:after{content:"";position:absolute;inset:-3px;border-radius:7px;padding:3px;background:conic-gradient(from var(--cell-ring-angle),#ffd23f,#2bd2ff,#ff3fa4,#c98bff,#ffd23f);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:cell-ring-spin 1.1s linear infinite;pointer-events:none;z-index:4}@keyframes cell-ring-spin{to{--cell-ring-angle:360deg}}@keyframes cell-halo-pulse{0%,to{box-shadow:inset 0 0 6px 1px rgba(255,240,200,.7),0 0 7px 1px rgba(255,210,120,.8),0 0 14px 2px rgba(201,139,255,.45)}50%{box-shadow:inset 0 0 9px 2px rgba(255,245,210,1),0 0 12px 3px rgba(255,210,120,1),0 0 22px 5px rgba(201,139,255,.75)}}@media (prefers-reduced-motion:reduce){.chart-cell-highlight,.chart-cell-highlight:after{animation:none}}.chart-cell-double{color:#1f1608;border:1px solid #c5a26f;box-shadow:inset 0 1px 0 rgba(255,255,255,.35);background-size:220% 100%;animation:shimmer-gold 2.4s linear infinite}.chart-cell-double-pure{background:linear-gradient(115deg,#a37d3a,#d4af37 18%,#f0d9a0 38%,#d4af37 58%,#a37d3a)}.chart-cell-double-hit{background:linear-gradient(115deg,#8f7a3a,#c5a26f 15%,#b8d38a 35%,#c5a26f 55%,#8f7a3a);border-color:#4ade80;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 0 0 1px rgba(74,222,128,.25)}.chart-cell-double-stand{background:linear-gradient(115deg,#8f7a3a,#c5a26f 15%,#d8a08a 35%,#c5a26f 55%,#8f7a3a);border-color:#f87171;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 0 0 1px rgba(248,113,113,.25)}.chart-cell-double-das{background:linear-gradient(115deg,#b8860b,#e8c96a 20%,#f5e2a0 40%,#e8c96a 60%,#b8860b);border-color:#facc15;animation-duration:2.1s}@keyframes shimmer-gold{0%{background-position:180% 50%}to{background-position:-80% 50%}}.chart-cell-sur{background:#f8f6f1;color:#111;border:1px solid #d1cdc3}.legend{list-style:none;padding:0;margin:var(--space-4) 0 0;display:flex;flex-wrap:wrap;gap:.65rem .9rem;font-size:.86rem}.legend li{display:inline-flex;align-items:center;gap:.45rem}.legend-chip{display:inline-block;min-width:1.85rem;padding:.12rem .42rem;border-radius:5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700;font-size:.72rem;text-align:center;border:1px solid rgba(255,255,255,.1)}.legend-chip-double{color:#1f1608!important;border:1px solid #c5a26f!important;background-size:200% 100%!important;animation:shimmer-gold 2.8s linear infinite!important}.legend-chip-double-pure{background:linear-gradient(115deg,#a37d3a,#d4af37,#f0d9a0,#d4af37,#a37d3a)!important}.legend-chip-double-hit{background:linear-gradient(115deg,#8f7a3a,#c5a26f,#b8d38a,#c5a26f,#8f7a3a)!important;border-color:#4ade80!important}.legend-chip-double-stand{background:linear-gradient(115deg,#8f7a3a,#c5a26f,#d8a08a,#c5a26f,#8f7a3a)!important;border-color:#f87171!important}.legend-chip-double-das{background:linear-gradient(115deg,#b8860b,#e8c96a,#f5e2a0,#e8c96a,#b8860b)!important;border-color:#facc15!important;animation-duration:2.2s!important}.legend-chip-sur{background:#f8f6f1!important;color:#111!important;border-color:#d1cdc3!important}.legend-desc{color:var(--muted)}.rules-section{margin-bottom:var(--space-6)}.rules-toggles{display:flex;flex-direction:column;gap:var(--space-2)}.rules-charts-grid{display:grid;grid-gap:var(--space-8);gap:var(--space-8);grid-template-columns:1fr}@media (min-width:920px){.rules-charts-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-5)}.rules-charts-grid .rules-section{margin-bottom:0}}.palace,.trainer{gap:var(--space-3)}.palace,.table,.trainer{display:flex;flex-direction:column}.table{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5);gap:var(--space-5)}.hand{display:flex;flex-direction:column;gap:var(--space-2)}.hand-label{display:flex;align-items:baseline;gap:var(--space-3);color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.hand-total{color:var(--accent);font-weight:700;font-size:.95rem}.hand-cards{display:flex;gap:0;align-items:flex-start;flex-wrap:nowrap;overflow:visible}.hand-cards .hand-card{width:var(--card-w,82px);height:auto;flex-shrink:0;transition:transform .15s ease,box-shadow .15s ease}.hand-cards .hand-card:hover{transform:translateY(-3px) scale(1.01);z-index:10!important}@media (max-width:420px){.hand-cards{--overlap:-22px}}.hand-card{border-radius:8px;background:var(--card-bg);box-shadow:0 3px 8px rgba(0,0,0,.35),0 1px 2px rgba(0,0,0,.2);display:block;height:auto;border:1px solid rgba(0,0,0,.08);transition:transform .15s ease}.trainer-loading{color:var(--muted);padding:2.5rem 1rem;text-align:center}.trainer-stage,.trainer-stage-main{display:flex;flex-direction:column;gap:var(--space-5)}.trainer-stage-main{min-width:0}.trainer-mini-chart{display:flex;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch}@media (min-width:860px){.trainer-stage{flex-direction:row;align-items:flex-start;gap:var(--space-6)}.trainer-stage-main{flex:1 1}.trainer-mini-chart{flex:0 0 auto}}.action-bar{display:flex;gap:var(--space-3);flex-wrap:wrap}.action-btn{flex:1 1 7.5rem;min-width:7.5rem;padding:.75rem .9rem;border-radius:10px;background:var(--bg-elev);color:var(--fg);border:1px solid var(--accent);cursor:pointer;font-size:.95rem;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .1s cubic-bezier(.2,0,0,1);min-height:64px;justify-content:center}.action-btn:hover:not(:disabled){background:var(--accent-subtle);border-color:var(--accent-hover)}.action-btn:active:not(:disabled){transform:translateY(1px) scale(.985)}.action-btn:disabled{opacity:.45;cursor:not-allowed;border-color:var(--border)}.action-btn--S{border-color:#b91c1c;color:#f5c6c6}.action-btn--S:hover:not(:disabled){background:rgba(185,28,28,.18);border-color:#ef4444}.action-btn--H{border-color:#15803d;color:#a7e8b8}.action-btn--H:hover:not(:disabled){background:rgba(21,128,61,.18);border-color:#22c55e}.action-btn--D,.action-btn--DH,.action-btn--DS{border-color:#c5a26f;color:#f0d9a0;position:relative;overflow:hidden}.action-btn--D:hover:not(:disabled),.action-btn--DH:hover:not(:disabled),.action-btn--DS:hover:not(:disabled){background:rgba(197,162,111,.15);border-color:#d4af37}.action-btn--D:after,.action-btn--DH:after,.action-btn--DS:after{content:"";position:absolute;inset:-40% -100%;background:linear-gradient(115deg,transparent 25%,rgba(255,255,255,.45) 50%,transparent 75%);background-size:220% 100%;animation:shimmer-gold 2.1s linear infinite;pointer-events:none;opacity:.6}.action-btn--SUR{border-color:#d1cdc3;color:#e8e4d9;background:rgba(248,246,241,.06)}.action-btn--SUR:hover:not(:disabled){background:rgba(248,246,241,.18);border-color:#f8f6f1;color:#111}.action-btn--Y{border-color:#15803d;color:#a7e8b8}.action-btn--Y:hover:not(:disabled){background:rgba(21,128,61,.18);border-color:#22c55e}.action-label{font-size:.97rem;font-weight:600}.action-key{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.68rem;color:var(--muted);background:rgba(0,0,0,.3);padding:.03rem .32rem;border-radius:3px;margin-top:1px}.action-bar-bottom{position:fixed;left:0;right:0;bottom:0;z-index:90;background:rgba(18,21,29,.97);border-top:1px solid var(--border);padding:var(--space-3) var(--space-3) calc(var(--space-3) + env(safe-area-inset-bottom, 0));display:none;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.action-bar-bottom .action-bar{gap:var(--space-2)}.action-bar-bottom .action-btn{min-height:58px;padding:.55rem .6rem;font-size:.9rem}.feedback{border-radius:var(--radius);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);border:1px solid var(--border)}.feedback-correct{background:rgba(15,61,42,.45);border-color:var(--success-border)}.feedback-wrong{background:rgba(58,31,35,.45);border-color:var(--error-border)}.feedback-headline{font-size:1.02rem;font-weight:700;color:var(--accent)}.feedback-body{color:var(--fg-secondary);line-height:1.4}.feedback-body code{background:rgba(0,0,0,.3);padding:.08rem .3rem;border-radius:3px;font-size:.85em}.feedback-next{align-self:flex-start;margin-top:var(--space-2);padding:.55rem 1.1rem;border-radius:var(--radius-sm);border:1px solid var(--accent);background:transparent;color:var(--accent);font-weight:600;cursor:pointer;font-size:.92rem;transition:all .1s ease}.feedback-next:hover{background:var(--accent-subtle)}.palace-controls{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;padding-bottom:0}.palace-filter-label{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600}.palace-filter{display:inline-flex;align-items:center;gap:.3rem;color:var(--fg-secondary)}.palace-filter,.palace-next{cursor:pointer;font-size:.9rem}.palace-next{margin-left:auto;padding:.5rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--accent);background:transparent;color:var(--accent);font-weight:600;transition:all .1s ease}.palace-next:hover{background:var(--accent-subtle)}.palace-answer{display:flex;align-items:baseline;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elev);border-left:3px solid var(--accent);border-radius:var(--radius-sm);flex-wrap:wrap;font-size:.9rem}.palace-answer-key{color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem}.palace-answer-value code{background:rgba(0,0,0,.28);padding:.06rem .28rem;border-radius:3px;font-size:.82em;margin-right:.2rem}.palace-stage,.palace-stage-hand{display:flex;flex-direction:column;gap:var(--space-5)}.palace-stage-hand .hand-label{font-size:.88rem}.palace-stage-hand .hand-total{font-size:1.15rem}.palace .palace-answer{font-size:1.02rem}.palace .palace-answer-key{font-size:.9rem}.palace-chart{display:flex;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch}@media (min-width:900px){.palace-stage{flex-direction:row;align-items:flex-start;gap:var(--space-6)}.palace-stage-hand{flex:0 0 auto;width:clamp(220px,26vw,300px);position:-webkit-sticky;position:sticky;top:var(--space-5)}.palace-chart{flex:1 1 auto;min-width:0}}.stats-summary{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;padding:.8rem 1rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--space-6);font-size:.92rem}.stats-reset{margin-left:auto;padding:.4rem .8rem;border-radius:7px;border:1px solid var(--error-border);background:transparent;color:#e88a7f;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .1s ease}.stats-reset:hover{background:rgba(92,47,53,.3)}.stats-section{margin-bottom:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.stats-charts-grid{display:grid;grid-gap:var(--space-6);gap:var(--space-6);grid-template-columns:1fr}@media (min-width:920px){.stats-charts-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-4)}}.settings-section{display:flex;flex-direction:column;gap:var(--space-4);max-width:58ch}.settings-toggle{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;grid-column-gap:var(--space-3);column-gap:var(--space-3);grid-row-gap:.2rem;row-gap:.2rem;padding:var(--space-4);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;transition:border-color .1s ease}.settings-toggle:hover{border-color:var(--border-strong)}.settings-toggle input[type=checkbox]{grid-row:1/span 2;width:1.15rem;height:1.15rem;accent-color:var(--accent)}.settings-label{font-weight:600;font-size:.95rem}.settings-hint{color:var(--muted);font-size:.82rem;grid-column:2;line-height:1.35}.settings-hint code{background:rgba(0,0,0,.3);padding:.05rem .28rem;border-radius:3px;font-size:.82em}@media (max-width:768px){.container{padding:1.35rem var(--space-4) 4rem}.tiles{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.action-btn{min-height:58px;font-size:.9rem}}@media (max-width:640px){.container{padding:1.1rem var(--space-3) 5rem}h1{font-size:1.55rem}.site-nav{padding:.6rem var(--space-3)}.nav-links{display:none}.mobile-bottom-nav{display:block}.chart{padding:.5rem}.hand-card{box-shadow:0 2px 5px rgba(0,0,0,.3)}.palace-controls,.stats-summary{font-size:.85rem}.action-bar{gap:var(--space-2)}}@media (max-width:380px){.action-btn{min-width:4.8rem;flex:1 1 4.8rem;padding:.55rem .35rem;font-size:.82rem}}@media (min-width:1024px){.chart{padding:.85rem}.container{padding-left:2rem;padding-right:2rem}}@media (prefers-reduced-motion:reduce){.action-btn,.feedback-next,.hand-card,.palace-next,.tile{transition:none}}