:root{--c-primary:#8b5a2b;--c-primary-light:#c49a6f;--c-primary-dark:#6b4423;--c-accent:#d4a046;--c-tropical:#2e8b57;--c-tropical-light:#5cb07a;--c-sky-top:#ffe4b5;--c-sky-bottom:#faf3e6;--c-asphalt:#4a4a4a;--c-grass:#7cb342;--c-sand:#e8d8b0;--c-cream:#faf3e6;--c-white:#fff;--c-text-dark:#3d2817;--c-text-muted:#6b4423;--c-text-subtle:#8b7355;--c-danger:#c24f1f;--c-gold:#d4a046;--c-silver:#c0a98b;--c-bronze:#b07a3b;--font-display:'Playfair Display' , serif;--font-body:'DM Sans' , sans-serif;--t-fast:150ms;--t-base:250ms;--t-slow:400ms;--shadow-sm:0 1px 3px rgba(61,40,23,.10);--shadow-md:0 4px 12px rgba(61,40,23,.12);--shadow-lg:0 8px 30px rgba(61,40,23,.18);--shadow-glow:0 0 20px rgba(212,160,70,.35)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family: var(--font-body);background:linear-gradient(135deg,var(--c-sky-bottom) 0%,var(--c-cream) 50%,var(--c-sky-bottom) 100%);color:var(--c-text-dark);line-height:1.6;min-height:100vh}a{color:var(--c-primary);text-decoration:none}a:hover{color:var(--c-primary-dark);text-decoration:underline}img{max-width:100%;height:auto}.site{display:flex;flex-direction:column;min-height:100vh}.site-header{background:var(--c-white);border-bottom:2px solid var(--c-primary);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-inner{max-width:1000px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;justify-content:space-between}.logo-img{display:block;height:72px;width:auto}.header-nav{display:flex;gap:20px}.header-nav a{font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--c-text-muted);transition:color var(--t-fast)}.header-nav a:hover{color:var(--c-primary);text-decoration:none}.site-main{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.page-hero{position:relative;width:100%;height:240px;overflow:hidden;background-color:var(--c-primary-dark);background-size:cover;background-position:center 40%}.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(14,89,12,.62) 0%,rgba(113,181,7,.45) 60%,rgba(0,0,0,.50) 100%)}.page-hero-inner{position:relative;z-index:1;max-width:1170px;margin:0 auto;height:100%;padding:20px 24px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;gap:6px}.page-hero-eyebrow{font-family: var(--font-body);font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-primary-light);text-shadow:0 1px 2px rgba(0,0,0,.45)}.page-hero-title{font-family: var(--font-display);font-style:italic;font-weight:900;font-size:clamp(1.8rem,4.5vw,3rem);line-height:1.05;color:var(--c-white);text-shadow:0 2px 12px rgba(0,0,0,.45);margin:0}.page-hero-sub{font-size:.95rem;color:var(--c-white);opacity:.92;max-width:640px;text-shadow:0 1px 6px rgba(0,0,0,.45)}.site-footer{text-align:center;padding:16px 20px;font-size:.8rem;color:var(--c-text-subtle);border-top:1px solid rgba(0,0,0,.06)}.site-footer a{color:var(--c-text-muted)}.copyright{margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border:2px solid transparent;border-radius:8px;font-family: var(--font-body);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--t-fast);text-decoration:none;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--c-primary);color:var(--c-white);border-color:var(--c-primary);box-shadow:0 2px 8px rgba(139,90,43,.30)}.btn-primary:hover:not(:disabled) {background:var(--c-primary-dark);border-color:var(--c-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn-ghost{background:transparent;color:var(--c-primary);border-color:var(--c-primary-light)}.btn-ghost:hover:not(:disabled) {background:rgba(139,90,43,.10);border-color:var(--c-primary)}.btn-large{padding:16px 48px;font-size:1.15rem;border-radius:10px}.btn-small{padding:6px 14px;font-size:.8rem}.btn-filter{background:var(--c-white);color:var(--c-text-muted);border-color:rgba(0,0,0,.1);padding:8px 16px;font-size:.85rem}.btn-filter.active{background:var(--c-primary);color:var(--c-white);border-color:var(--c-primary)}.intro-section{width:100%;max-width:640px}.intro-card{background:var(--c-white);border-radius:16px;padding:40px 32px;box-shadow:var(--shadow-lg);text-align:center}.intro-title{font-family: var(--font-display);font-style:italic;font-size:1.8rem;font-weight:700;color:var(--c-primary-dark);margin-bottom:8px;line-height:1.2}.intro-subtitle{color:var(--c-text-muted);margin-bottom:28px;font-size:.95rem}.tutorial-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px}.tutorial-card{background:var(--c-cream);border-radius:10px;padding:16px 10px;text-align:center}.tutorial-icon{font-size:1.8rem;margin-bottom:6px}.tutorial-card h3{font-size:.85rem;font-weight:700;color:var(--c-primary-dark);margin-bottom:4px}.tutorial-card p{font-size:.75rem;color:var(--c-text-muted);line-height:1.3}.intro-ranking{margin-top:24px}.game-section{width:100%;max-width:1170px}.game-wrapper{position:relative;max-width:1040px;margin:0 auto;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid var(--c-primary);background:var(--c-asphalt)}.game-wrapper canvas{display:block;width:100%!important;height:auto!important}.game-legend{max-width:1040px;margin:16px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:14px}.legend-group{background:var(--c-white);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm);border-top:4px solid var(--c-primary)}.legend-group.legend-bad{border-top-color:var(--c-primary-dark)}.legend-sub{font-family: var(--font-display);font-style:italic;font-weight:700;font-size:1.05rem;color:var(--c-primary-dark);margin-bottom:10px;display:flex;align-items:center;gap:8px}.legend-group.legend-good .legend-sub::before{content:"✓";color:var(--c-primary);font-weight:900}.legend-group.legend-bad .legend-sub::before{content:"✕";color:var(--c-primary-dark);font-weight:900}.legend-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.legend-list li{display:flex;gap:12px;align-items:center;font-size:.85rem;line-height:1.35;color:var(--c-text-dark)}.legend-icon{flex:0 0 40px;width:40px;height:40px;background:var(--c-cream);border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,0,0,.06)}.legend-icon img{display:block;max-width:100%;height:auto}.legend-meta{font-size:.78rem;color:var(--c-text-muted)}.modal-backdrop{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn var(--t-base) ease-out}.modal{background:var(--c-white);border-radius:16px;padding:32px 28px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scaleIn var(--t-slow) ease-out}.modal-title{font-family: var(--font-display);font-style:italic;font-size:1.6rem;font-weight:700;color:var(--c-primary-dark);text-align:center;margin-bottom:4px}.modal-subtitle{text-align:center;color:var(--c-text-muted);font-size:.9rem;margin-bottom:20px}.score-display{background:linear-gradient(135deg,rgba(113,181,7,.08),rgba(188,226,184,.18));border:2px solid var(--c-primary-light);border-radius:12px;padding:20px;text-align:center;margin-bottom:16px}.score-value{font-family: var(--font-display);font-style:italic;font-size:3rem;font-weight:900;color:var(--c-primary);line-height:1}.score-label{font-size:.85rem;color:var(--c-text-muted);margin-bottom:12px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.stat{text-align:center}.stat-value{display:block;font-size:1.2rem;font-weight:700;color:var(--c-primary-dark)}.stat-label{font-size:.75rem;color:var(--c-text-subtle);text-transform:uppercase;letter-spacing:.05em}.rank-info{text-align:center;font-weight:600;color:var(--c-eco);padding:8px;background:rgba(139,90,43,.10);border-radius:8px;margin-bottom:16px;font-size:.9rem}.pszok-banner{background:linear-gradient(135deg,#bce2b8,#f6f7f4);border:2px solid var(--c-accent);border-radius:10px;padding:14px 16px;text-align:center;font-size:.85rem;color:var(--c-text-dark);margin-bottom:16px;line-height:1.5}.score-form{margin-top:8px}.field{margin-bottom:12px;text-align:left}.field label{display:block;font-size:.85rem;font-weight:500;color:var(--c-text-muted);margin-bottom:4px}.field input[type="text"]{width:100%;padding:10px 14px;border:2px solid rgba(0,0,0,.1);border-radius:8px;font-family: var(--font-body);font-size:1rem;color:var(--c-text-dark);background:var(--c-cream);transition:border-color var(--t-fast)}.field input[type="text"]:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(113,181,7,.20);background:var(--c-white)}.field-error{font-size:.8rem;color:var(--c-danger);margin-top:4px;display:none}.field-error.show{display:block}.form-buttons{display:flex;gap:10px;flex-wrap:wrap}.form-buttons .btn{flex:1;min-width:140px}.score-saved{text-align:center}.saved-msg{font-weight:700;color:var(--c-eco);font-size:1.1rem;margin-bottom:16px}.ranking-list{margin-top:12px}.ranking-row{display:grid;grid-template-columns:42px 1fr auto;gap:8px;align-items:center;padding:8px 12px;border-bottom:1px solid rgba(0,0,0,.04);font-size:.9rem}.ranking-list--full .ranking-row{grid-template-columns:42px 1fr auto auto}.ranking-row .rank{font-weight:700;text-align:center;color:var(--c-text-muted)}.ranking-row .nick{font-weight:500;color:var(--c-text-dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-row .score{font-weight:700;color:var(--c-primary);font-variant-numeric:tabular-nums;text-align:right}.ranking-row .detail{font-size:.75rem;color:var(--c-text-subtle);text-align:right;white-space:nowrap}.ranking-row.top-3 .rank{color:var(--c-gold)}.ranking-row.top-3:nth-child(2) .rank {color:var(--c-silver)}.ranking-row.top-3:nth-child(3) .rank {color:var(--c-bronze)}.ranking-row.is-current-player{background:rgba(139,90,43,.10);border-left:3px solid var(--c-primary);border-radius:4px}.hof-page{width:100%;max-width:640px}.page-title{font-family: var(--font-display);font-style:italic;font-size:1.8rem;font-weight:700;color:var(--c-primary-dark);text-align:center;margin-bottom:20px}.hof-filters{display:flex;gap:8px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}.hof-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px}.page-info{font-size:.85rem;color:var(--c-text-muted)}.hof-total{text-align:center;font-size:.85rem;color:var(--c-text-subtle);margin-top:12px}.text-muted{color:var(--c-text-muted);text-align:center;padding:20px}.legal-page{max-width:640px;background:var(--c-white);border-radius:16px;padding:40px 32px;box-shadow:var(--shadow-md)}.legal-page h1{font-family: var(--font-display);font-style:italic;font-size:1.5rem;color:var(--c-primary-dark);margin-bottom:24px}.legal-page h2{font-size:1rem;font-weight:700;color:var(--c-text-dark);margin:20px 0 8px}.legal-page p,.legal-page li{font-size:.9rem;color:var(--c-text-muted);margin-bottom:8px}.legal-page ul{padding-left:20px}.legal-date{margin-top:24px;font-style:italic;font-size:.8rem;color:var(--c-text-subtle)}.toast-stack{position:fixed;bottom:20px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px}.toast{background:var(--c-white);border-radius:8px;padding:12px 16px;box-shadow:var(--shadow-md);font-size:.85rem;border-left:3px solid var(--c-eco);animation:slideInRight var(--t-base) ease-out;max-width:320px}.toast.error{border-left-color:var(--c-danger)}@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}@keyframes scaleIn {
    from { opacity: 0; transform: scale(0.92) translateY(10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}@keyframes slideInRight {
    from { opacity: 0; transform: translateX(20px); }
    to { opacity: 1; transform: translateX(0); }
}@media (max-width:640px){.header-inner{padding:10px 14px}.logo-img{height:52px}.page-hero{height:160px}.page-hero-inner{padding:16px 16px}.page-hero-eyebrow{font-size:.7rem;letter-spacing:.14em}.page-hero-sub{font-size:.85rem}.header-nav{gap:12px}.header-nav a{font-size:.75rem}.site-main{padding:12px}.intro-card{padding:24px 16px}.intro-title{font-size:1.4rem}.tutorial-cards{grid-template-columns:1fr;gap:8px}.tutorial-card{display:flex;align-items:center;gap:12px;text-align:left;padding:12px}.tutorial-icon{font-size:1.4rem;margin-bottom:0;flex-shrink:0}.modal{padding:24px 18px}.modal-title{font-size:1.3rem}.score-value{font-size:2.2rem}.form-buttons{flex-direction:column}.form-buttons .btn{min-width:auto}.game-wrapper{max-width:100%;border-radius:8px}.game-legend{grid-template-columns:1fr;max-width:720px;gap:10px}.legend-group{padding:12px 14px}.legend-list li{font-size:.8rem}}.page-hero--travel{background:linear-gradient(135deg,#8b5a2b 0%,#d4a046 50%,#ffe4b5 100%);background-color:#8b5a2b}.page-hero--travel::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(107,68,35,.45) 0%,rgba(212,160,70,.30) 60%,rgba(0,0,0,.30) 100%)}.logo-img{height:60px;width:auto}.oversized-banner{background:linear-gradient(135deg,#fff4dc 0%,#faf3e6 100%);border:2px solid var(--c-accent);border-radius:8px;padding:12px 16px;margin:16px 0;font-size:.92rem;color:var(--c-text-dark);text-align:center;box-shadow:var(--shadow-sm)}.oversized-banner strong{color:var(--c-primary-dark);display:inline-block;margin-bottom:4px}.oversized-banner a{color:var(--c-primary);font-weight:600}.tagline{font-family: var(--font-display);font-style:italic;color:var(--c-primary-dark);font-size:1rem;margin-bottom:6px}@media (hover:none) and (pointer:coarse) and (orientation:landscape){body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .site-header {display:none}body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .site-main {padding:0;align-items:stretch}body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .site-footer {display:none}body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .game-section {max-width:100%;width:100vw;height:100vh;height:100dvh}body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .game-wrapper {max-width:100%;width:100vw;height:100vh;height:100dvh;border:none;border-radius:0;margin:0}body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .game-wrapper canvas {width:100%!important;height:100%!important;max-height:100vh;max-height:100dvh}body:has(#game-section:not([style*="display:none"]):not([style*="display: none"])) .game-legend {display:none}}.game-fullscreen .site-header,.game-fullscreen .site-footer,.game-fullscreen .game-legend{display:none!important}.game-fullscreen .site-main{padding:0!important;align-items:stretch!important}.game-fullscreen .game-section,.game-fullscreen .game-wrapper{max-width:100%!important;width:100vw!important;height:100vh!important;height:100dvh!important;margin:0!important;border:none!important;border-radius:0!important}.game-fullscreen .game-wrapper canvas{width:100%!important;height:100%!important;max-height:100vh!important;max-height:100dvh!important}.rotate-gate{display:none;position:fixed;inset:0;z-index:10000;background:linear-gradient(135deg,#3d2817 0%,#6b4423 50%,#8b5a2b 100%);color:#faf3e6;align-items:center;justify-content:center;text-align:center;padding:24px}.rotate-gate.active{display:flex}.rotate-gate-inner{max-width:360px}.rotate-phone-anim{position:relative;width:80px;height:140px;margin:0 auto 28px;border:4px solid #faf3e6;border-radius:14px;background:linear-gradient(180deg,#d4a046 0%,#8b5a2b 100%);animation:rotatePhoneAnim 2.5s ease-in-out infinite;transform-origin:center;box-shadow:0 8px 24px rgba(0,0,0,.4)}.rotate-phone-anim::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:30px;height:4px;background:#faf3e6;border-radius:2px;opacity:.6}.rotate-phone-anim::after{content:"";position:absolute;bottom:8px;left:50%;transform:translateX(-50%);width:16px;height:16px;border:2px solid #faf3e6;border-radius:50%;opacity:.6}@keyframes rotatePhoneAnim {
    0%, 15% { transform: rotate(0deg); }
    50%, 75% { transform: rotate(-90deg); }
    100% { transform: rotate(0deg); }
}.rotate-arrow{font-size:2.4rem;color:#d4a046;margin:8px 0 16px;animation:arrowPulse 1.5s ease-in-out infinite}@keyframes arrowPulse {
    0%, 100% { transform: translateX(0); opacity: 0.7; }
    50% { transform: translateX(8px); opacity: 1; }
}.rotate-gate h2{font-family: var(--font-display);font-style:italic;font-size:1.9rem;margin-bottom:12px;color:#faf3e6}.rotate-gate p{font-size:1rem;line-height:1.5;opacity:.95;margin-bottom:6px}.rotate-gate-hint{font-size:.85rem;opacity:.75;margin-top:18px;font-style:italic}