@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg: #F7F2E8;--panel: #FFFCF5;--surface: #F2ECE1;--text: #1F2A30;--muted: #667074;--accent: #65AFA9;--accent-hover: #4F9892;--accent-strong: #2F6FD0;--success: #2F8F4D;--error: #D84A3F;--stroke: #D8CCBA;--stroke-soft: #C6B9A6;--guess: #E2AE3F;--comarca-fill: #D8D0C2;--comarca-stroke: #AFA392;--shadow: rgba(31, 42, 48, .1);--border: #D8CCBA;--button-font: clamp(.94rem, .82rem + .28vw, 1.04rem);--button-font-strong: clamp(.98rem, .84rem + .32vw, 1.08rem);--header-button-min-height: clamp(50px, calc(42px + 1vw) , 56px);--header-button-padding-y: clamp(10px, calc(6px + .55vw) , 13px);--header-button-padding-x: clamp(12px, calc(8px + 1vw) , 18px);--action-button-min-height: clamp(48px, calc(40px + 1vw) , 52px);--action-button-padding-y: clamp(10px, calc(6px + .55vw) , 13px);--action-button-padding-x: clamp(12px, calc(8px + 1vw) , 18px);--compact-button-min-height: clamp(44px, calc(12px + 3vw) , 54px);--compact-button-padding-y: clamp(9px, calc(5px + .65vw) , 13px);--compact-button-padding-x: clamp(11px, calc(7px + 1vw) , 20px);--desktop-panel-column: clamp(400px, 31vw, 480px);--map-control-size: clamp(42px, 4.6vw, 48px);--map-recenter-width: clamp(84px, 9.4vw, 102px);--map-control-gap: clamp(6px, .75vw, 9px);--map-control-font: clamp(.82rem, .72rem + .35vw, .95rem);--map-control-offset: clamp(10px, 1.5vw, 14px);--map-control-padding-y: clamp(7px, .8vw, 9px);--map-control-padding-x: clamp(9px, 1vw, 12px);--app-height: 100vh;--app-height: 100svh;--page-pad-x: clamp(14px, 2vw, 26px);--page-pad-top: clamp(12px, 2.2vh, 20px);--page-pad-bottom: clamp(14px, 2.6vh, 24px);--page-gap: clamp(12px, 2vh, 18px);--layout-gap: clamp(14px, 1.7vw, 20px)}*,*:before,*:after{box-sizing:border-box}html{min-width:0;min-height:100%;overflow-x:hidden}#root{min-width:0;min-height:100%}body{margin:0;font-family:Space Grotesk,IBM Plex Sans,Helvetica Neue,sans-serif;font-size:18px;background:var(--bg);color:var(--text);min-height:var(--app-height);height:var(--app-height);overflow:hidden;overflow-x:hidden;position:relative}button,input,select,textarea{max-width:100%}img,svg{max-width:100%}:where(.page,.topbar,.brand,.brand-row,.topbar-right,.topbar-actions,.game-layout,.map-wrap,.map-stage,.side-panel,.panel-card,.calendar-panel,.calendar-header,.calendar-body,.calendar-month,.calendar-grid,.modal,.tutorial-shell,.tutorial-copy,.result-modal){min-width:0}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:0;transition:opacity .4s ease}html[data-weather=clear] body:before{opacity:.12;background:radial-gradient(circle at 20% 15%,rgba(255,215,150,.28),transparent 55%),radial-gradient(circle at 80% 20%,rgba(255,230,180,.1),transparent 60%)}html[data-weather=clouds] body:before{opacity:.15;background:linear-gradient(140deg,rgba(130,150,175,.18),transparent 65%)}html[data-weather=rain] body:before{opacity:.25;background-image:repeating-linear-gradient(120deg,rgba(60,110,200,.14),rgba(60,110,200,.14) 1px,transparent 1px,transparent 6px);animation:rain-shift 4s linear infinite}html[data-weather=storm] body:before{opacity:.2;background:linear-gradient(160deg,rgba(40,40,70,.18),transparent 70%);animation:storm-flash 6s ease-in-out infinite}html[data-weather=snow] body:before{opacity:.22;background-image:radial-gradient(rgba(100,140,200,.45) 1px,transparent 1px);background-size:18px 18px;animation:snow-fall 10s linear infinite}html[data-weather=fog] body:before{opacity:.25;background:linear-gradient(0deg,rgba(150,160,170,.14),transparent 70%)}html[data-weather=wind] body:before{opacity:.18;background-image:repeating-linear-gradient(20deg,rgba(90,130,180,.12),rgba(90,130,180,.12) 2px,transparent 2px,transparent 10px);animation:wind-shift 5s linear infinite}.page{padding:max(var(--page-pad-top),env(safe-area-inset-top)) max(var(--page-pad-x),env(safe-area-inset-right)) max(var(--page-pad-bottom),env(safe-area-inset-bottom)) max(var(--page-pad-x),env(safe-area-inset-left));display:grid;gap:var(--page-gap);min-height:var(--app-height);height:var(--app-height);grid-template-rows:auto 1fr;position:relative;z-index:1;overflow:hidden}.topbar{display:grid;grid-template-columns:minmax(0,1fr) var(--desktop-panel-column);gap:var(--layout-gap);align-items:end}.brand{flex:1 1 auto;min-width:0;max-width:100%}.brand-row{display:flex;align-items:flex-end;column-gap:12px;min-width:0}.brand-date{flex:0 0 auto;align-self:flex-end;color:var(--muted);font-size:1rem;line-height:1;padding-bottom:8px;text-transform:none;white-space:nowrap}.brand-button{flex:0 0 auto;padding:0;border:none;background:none;color:inherit;cursor:pointer;text-align:left;display:inline-flex;align-items:flex-end;align-self:end;gap:14px;min-height:62px;white-space:nowrap}.brand-logo{display:block;width:76px;height:64px;flex:0 0 76px;overflow:visible;position:relative}.brand-logo-image{display:block;width:92px;height:92px;max-width:none;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.topbar-right{width:100%;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;justify-content:flex-end;padding-top:0;align-self:end}.topbar-actions{display:grid;grid-template-columns:minmax(0,1.16fr) minmax(0,.76fr) minmax(0,1.34fr);gap:10px;align-items:center;width:100%}.topbar-button{border:none;background:var(--accent);color:#fff;min-height:var(--header-button-min-height);font-size:var(--button-font-strong);font-weight:700;padding:var(--header-button-padding-y) var(--header-button-padding-x);border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:100%;white-space:nowrap;transition:background .15s}.topbar-button:hover{background:var(--accent-hover)}.topbar-challenge{border:1px solid var(--border);background:var(--panel);color:var(--text);min-height:var(--header-button-min-height);font-size:var(--button-font-strong);font-weight:700;padding:var(--header-button-padding-y) var(--header-button-padding-x);border-radius:8px;cursor:pointer;width:100%;white-space:nowrap;box-shadow:0 1px 3px var(--shadow);transition:background .15s,border-color .15s}.topbar-challenge:hover{background:var(--surface)}.topbar-challenge.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--panel))}.topbar-challenge:disabled{opacity:.55;cursor:not-allowed}.calendar-icon-button{border:1px solid var(--border);background:var(--panel);color:var(--text);min-height:var(--header-button-min-height);font-size:var(--button-font-strong);font-weight:700;padding:var(--header-button-padding-y) var(--header-button-padding-x);border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;white-space:nowrap;box-shadow:0 1px 3px var(--shadow);transition:background .15s}.calendar-icon-button:hover{background:var(--surface)}.topbar-calendar{justify-self:end}.calendar-icon{width:21px;height:21px;border:1px solid currentColor;border-radius:4px;position:relative}.calendar-icon:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:currentColor;opacity:.45;border-top-left-radius:4px;border-top-right-radius:4px}.calendar-icon:after{content:"";position:absolute;top:9px;left:3px;right:3px;height:1px;background:currentColor;opacity:.3}.topbar-button:disabled{opacity:.55;cursor:not-allowed}button:focus-visible,[role=button]:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.calendar-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.calendar-toggle-button{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:10px;padding:7px 9px;font-size:.86rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;line-height:1.12}.calendar-toggle-button.active{border-color:var(--accent);box-shadow:0 0 0 2px #76b4b038}.calendar-toggle-button:disabled{opacity:.5;cursor:not-allowed}.status-stack{display:grid;gap:6px;justify-items:end}.status-badge{font-size:.76rem;padding:5px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:0}.status-badge.offline{background:#d16d5c1f;color:#b84f3e;border:1px solid rgba(209,109,92,.35)}.status-badge.warn{background:#c9a76a24;color:#7a5a1a;border:1px solid rgba(201,167,106,.4)}.streak-card{display:grid;gap:4px;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:10px 14px;min-width:160px;width:100%;box-shadow:0 1px 4px var(--shadow)}.calendar-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.calendar-tab{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:10px;padding:7px 9px;font-size:.82rem;cursor:pointer;transition:background .15s;min-width:0;line-height:1.12}.calendar-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.calendar-status{font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--success)}.calendar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--text) 35%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:flex-end;align-items:flex-start;padding:max(32px,env(safe-area-inset-top)) max(32px,env(safe-area-inset-right)) max(32px,env(safe-area-inset-bottom)) max(32px,env(safe-area-inset-left));z-index:50;overflow:hidden}.calendar-panel{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px;width:min(520px,calc(100vw - 64px - env(safe-area-inset-left) - env(safe-area-inset-right)));display:grid;gap:12px;grid-template-rows:auto auto minmax(0,1fr);box-shadow:0 24px 60px #1f2a302e;height:min(80vh,640px);height:min(80svh,640px);max-height:calc(100vh - 64px);max-height:calc(100svh - 64px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:hidden}.calendar-header{display:flex;justify-content:space-between;align-items:center}.icon-button{border:1px solid var(--border);background:var(--surface);color:var(--text);width:36px;height:36px;border-radius:8px;cursor:pointer;display:grid;place-items:center;font-size:1.18rem;box-shadow:0 1px 3px var(--shadow)}.calendar-body{display:grid;gap:12px;min-height:0;overflow:auto;overscroll-behavior:contain}.calendar-month{display:flex;align-items:center;justify-content:space-between;gap:12px}.calendar-month-label{font-weight:600;text-transform:none;min-width:0;overflow-wrap:anywhere}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);gap:6px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.calendar-day{position:relative;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:10px;padding:clamp(6px,1.35svh,9px) clamp(5px,1.2vw,7px);min-height:clamp(44px,8.5svh,60px);cursor:pointer;display:grid;align-content:start;gap:6px;transition:background .12s}.calendar-day:hover{background:#f0ebe0}.calendar-day.has-level{border-color:#5c86c566;background:#5c86c50f}.calendar-day.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.calendar-day.locked{opacity:.62;background:color-mix(in srgb,var(--surface) 82%,var(--muted) 18%);border-color:color-mix(in srgb,var(--border) 75%,var(--muted) 25%)}.calendar-day.muted{opacity:.35}.calendar-day.muted.locked{opacity:.42}.calendar-day.today{border-color:var(--accent);background:#76b4b012}.calendar-day.done{border-color:#3d8a5680}.calendar-day.loading{opacity:.72;cursor:wait}.calendar-day.skeleton{background:color-mix(in srgb,var(--text) 3%,transparent);border-color:transparent;cursor:default}.calendar-day-label{font-size:.98rem}.calendar-dot{width:6px;height:6px;border-radius:50%;background:var(--stroke-soft)}.calendar-dot.active{background:var(--accent-strong)}.calendar-dot.done{background:var(--success)}.calendar-dot.empty{background:var(--stroke-soft)}.calendar-dot.locked{background:color-mix(in srgb,var(--muted) 70%,transparent)}.calendar-popup{position:absolute;inset:auto 6px 6px 6px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:10px;display:grid;gap:6px;z-index:2;box-shadow:0 4px 14px var(--shadow)}.calendar-popup-button{border:none;background:var(--surface);color:var(--text);padding:7px 9px;border-radius:8px;cursor:pointer;font-size:.86rem;transition:background .12s}.calendar-popup-button:hover{background:color-mix(in srgb,var(--surface) 90%,var(--text))}.calendar-popup-button:disabled{opacity:.5;cursor:not-allowed}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.76rem;color:var(--muted);margin:0 0 8px}h1{margin:0;font-size:2.55rem;line-height:1;color:var(--text)}.subtitle{margin:8px 0 0;color:var(--muted);max-width:min(640px,100%)}.game-layout{display:grid;grid-template-columns:minmax(0,1fr) var(--desktop-panel-column);gap:var(--layout-gap);align-items:stretch;min-height:0;height:100%;overflow:hidden}.side-panel{display:grid;gap:16px;align-content:start;height:auto;max-height:none;overflow-y:visible;overflow-x:hidden;padding-right:0}.panel-card{background:var(--panel);padding:20px;border-radius:8px;border:1px solid var(--border);box-shadow:0 1px 6px var(--shadow);display:grid;gap:12px}.panel-card.panel-primary{box-shadow:0 0 0 2px #76b4b038,0 2px 8px var(--shadow)}.section-header,.action-header{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.action-card{gap:16px}.play-card{align-self:start}.action-progress{display:flex;flex-wrap:wrap;gap:10px 14px}.progress-item,.action-status{white-space:nowrap}.action-feedback{min-height:24px}.attempt-limit{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:56px;border:1px solid color-mix(in srgb,var(--accent) 24%,var(--border));border-radius:8px;background:color-mix(in srgb,var(--accent) 8%,var(--surface));padding:11px 14px;color:var(--text);font-size:1rem}.attempt-limit strong{color:var(--accent-strong);font-size:1.16rem}.options-card{gap:10px}.side-powerups{display:grid;gap:10px}.options-launch-button{width:100%;border:1px solid var(--border);background:var(--surface);color:var(--text);min-height:clamp(46px,calc(38px + 1vw),50px);padding:clamp(9px,calc(5px + .55vw),12px) 14px;border-radius:8px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.options-launch-button:hover{background:#76b4b01f;border-color:var(--accent)}.options-toggle{background:none;border:none;padding:0;color:inherit;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;text-align:left}.options-body{display:grid;gap:18px}.options-section{display:grid;gap:14px}.options-audio-controls{display:grid;grid-template-columns:minmax(130px,auto) minmax(0,1fr);gap:10px;align-items:center}.value.start{color:var(--accent-strong);font-weight:600}.value.target,.value.urgent{color:var(--error);font-weight:600}.value.dim{color:transparent}.value.is-perfect{color:var(--success);font-weight:600}.guess-form{display:grid;gap:10px}.suggestions{display:none;flex-direction:column;gap:8px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:8px;box-shadow:0 4px 14px var(--shadow)}.suggestions.is-open{display:flex}.suggestion{background:transparent;border:none;text-align:left;padding:11px 13px;border-radius:8px;color:var(--text);cursor:pointer;font-size:1.02rem;transition:background .12s}.suggestion:hover{background:#76b4b024}.suggestion.empty{cursor:default;color:var(--muted)}.guess-form input{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;color:var(--text);font-size:1.08rem;font-family:inherit;transition:border-color .15s,background .15s}.guess-form input::placeholder{color:var(--muted);opacity:.7}.guess-form input:focus{outline:2px solid var(--accent);outline-offset:1px;background:var(--panel)}.guess-form input.input-error{border-color:#d16d5cbf;box-shadow:0 0 0 2px #d16d5c29}.guess-form input:disabled{opacity:.6}.submit{background:var(--accent);color:#fff;border:none;border-radius:8px;min-height:var(--action-button-min-height);padding:var(--action-button-padding-y) var(--action-button-padding-x);font-weight:600;cursor:pointer;font-family:inherit;font-size:var(--button-font-strong);transition:background .15s}.submit:hover{background:var(--accent-hover)}.submit:disabled{opacity:.6;cursor:default}.new-game-button{width:100%;border:none;background:var(--accent-strong);color:#fff;min-height:var(--action-button-min-height);padding:var(--action-button-padding-y) var(--action-button-padding-x);border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .15s}.new-game-button:hover{opacity:.88}.new-game-button:disabled{opacity:.6;cursor:not-allowed}.feedback{min-height:18px;font-size:.85rem;color:var(--muted)}.feedback.good{color:var(--success)}.feedback.bad{color:var(--error)}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.stat{display:grid;gap:4px;font-size:.9rem}.stats-grid{display:grid;gap:8px}.stat-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.85rem}.stat-inline{display:inline-flex;align-items:baseline;gap:6px;font-size:.9rem}.guess-history{margin-top:8px}.guess-history-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}.guess-history-item{padding:4px 8px;border-radius:999px;font-size:.8rem;background:color-mix(in srgb,var(--text) 6%,transparent)}.guess-history-item.good{color:var(--success);border:1px solid rgba(61,138,86,.4)}.guess-history-item.near{color:#7a5a1a;border:1px solid rgba(201,167,106,.5)}.guess-history-item.bad{color:var(--error);border:1px solid rgba(209,109,92,.4)}.ranking-lists{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.ranking-list{margin:4px 0 0;padding-left:16px;color:var(--muted);display:grid;gap:4px}.achievements{display:grid;gap:8px}.achievement-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-size:.85rem}.achievement{padding:8px 10px;border-radius:10px;border:1px solid var(--border);color:var(--muted);font-size:.85rem}.achievement.unlocked{border-color:#76b4b08c;color:var(--text);background:#76b4b017}.modal-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch}.muted{color:var(--muted);font-size:.98rem}.label{color:var(--muted);text-transform:uppercase;letter-spacing:0;font-size:.78rem}.value{font-weight:600}.rule-chip{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:.98rem}.rule-chip.good{border-color:#3d8a568c;background:#3d8a5612}.rule-chip.bad{border-color:#d16d5c8c;background:#d16d5c12}.mission{display:grid;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--surface)}.mission.done{border-color:#3d8a5673;background:#3d8a5612}.mission-title{font-weight:600}.badge{align-self:start;display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:#76b4b024;color:var(--text);font-size:.86rem;border:1px solid rgba(118,180,176,.45)}.badge.success{border-color:#3d8a5680;background:#3d8a561a;color:var(--success)}.powerups{display:grid;gap:9px}.powerup-button{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;min-height:clamp(48px,calc(42px + .7vw),52px);padding:8px 12px;color:var(--text);cursor:pointer;font-family:inherit;font-weight:600;transition:background .12s,border-color .12s,transform .12s}.powerup-button:hover{background:color-mix(in srgb,var(--surface) 90%,var(--text));border-color:color-mix(in srgb,var(--accent) 50%,var(--border))}.powerup-button:active{transform:translateY(1px)}.powerup-button:disabled{opacity:.45;cursor:default}.theme-grid{display:grid;gap:8px}.theme-button{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text);cursor:pointer;transition:background .12s}.theme-button.active{border-color:var(--accent);background:#76b4b01f}.theme-button.locked{opacity:.7}.theme-button:disabled{opacity:.5;cursor:default}.lock{color:var(--muted);font-size:.75rem}.scope-buttons{display:grid;gap:6px;grid-template-columns:repeat(3,minmax(0,1fr))}.scope-button{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:6px 8px;color:var(--text);cursor:pointer;font-size:.8rem;transition:background .12s}.scope-button.active{border-color:var(--accent);background:#76b4b01f}.scope-button:disabled{opacity:.45;cursor:default}.group-controls{display:grid;gap:8px}.group-controls input{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 10px;color:var(--text);font-family:inherit}.group-row{display:grid;gap:6px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center}.group-row input{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 10px;color:var(--text);font-family:inherit}.ghost{background:transparent;border:1px dashed var(--stroke-soft);color:var(--muted);border-radius:10px;padding:8px 10px;cursor:pointer;font-size:.8rem;transition:border-color .12s}.ghost:hover{border-color:var(--stroke)}.ghost:disabled{opacity:.5;cursor:default}.history-list{margin:0;padding-left:0;list-style:none;display:grid;gap:8px;color:var(--muted)}.history-item{display:grid;gap:2px}.history-index{font-size:.75rem;color:var(--muted)}.history-main{font-size:.85rem;color:var(--text)}.reset{background:var(--accent);color:#fff;border:none;border-radius:8px;min-height:var(--compact-button-min-height);padding:var(--compact-button-padding-y) var(--compact-button-padding-x);font-family:inherit;font-weight:600;cursor:pointer;transition:background .15s,transform .12s,box-shadow .15s}.reset:hover{background:var(--accent-hover)}.reset:active{transform:translateY(1px)}.reset:disabled{cursor:not-allowed;opacity:.55}.result-secondary{min-height:var(--compact-button-min-height);border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);padding:var(--compact-button-padding-y) var(--compact-button-padding-x);font-family:inherit;font-weight:650;cursor:pointer;transition:background .15s,border-color .15s,transform .12s}.result-secondary:hover{background:color-mix(in srgb,var(--surface) 88%,var(--text));border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.result-secondary:active{transform:translateY(1px)}.result-secondary:disabled{cursor:not-allowed;opacity:.52}.path-list{margin:0;padding-left:0;list-style:none;color:var(--muted);display:grid;gap:6px;max-height:180px;overflow:auto}.guess-item{color:#7a5a1a}.shortest-list{margin:0;padding-left:18px;color:var(--muted);display:grid;gap:6px;max-height:180px;overflow:auto}.map-wrap{position:relative;display:grid;grid-template-rows:auto minmax(0,1fr);gap:10px;background:var(--surface);border-radius:8px;padding:12px;min-height:0;height:100%;overflow:hidden;border:1px solid var(--border);box-shadow:0 2px 10px var(--shadow)}.map-stage{position:relative;min-height:0;overflow:hidden;border-radius:6px}.map-timer{position:absolute;top:12px;left:12px;background:var(--panel);background:color-mix(in srgb,var(--panel) 90%,transparent);border:1px solid var(--border);padding:7px 12px;border-radius:8px;font-weight:600;font-size:1rem;z-index:4;color:var(--text);box-shadow:0 1px 4px var(--shadow)}.map-timer.urgent{color:var(--error);border-color:#d16d5c8c}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:color-mix(in srgb,var(--bg) 82%,transparent);z-index:5;font-size:4.35rem;font-weight:700}.countdown-value{color:var(--text);text-shadow:0 2px 8px rgba(255,255,255,.7)}.countdown-active .map,.countdown-active .prompt,.countdown-active .map-controls{opacity:0;pointer-events:none}.map-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--surface);background:color-mix(in srgb,var(--surface) 95%,transparent);color:var(--muted);font-size:1.04rem;z-index:3}.map-wrap.fog{background:var(--surface)}.map-wrap.completion-celebrating{border-color:color-mix(in srgb,var(--success) 55%,var(--border));box-shadow:0 8px 28px color-mix(in srgb,var(--success) 18%,transparent)}.prompt{position:relative;background:var(--panel);padding:12px 15px 13px;border-radius:8px;border:1px solid var(--border);box-shadow:0 1px 4px var(--shadow);font-size:1.06rem;display:grid;gap:6px;color:var(--text);max-width:none;min-width:0;z-index:2}.map-controls{position:absolute;top:var(--map-control-offset);right:var(--map-control-offset);display:flex;gap:var(--map-control-gap);z-index:2}.map-controls button{background:var(--panel);background:color-mix(in srgb,var(--panel) 90%,transparent);color:var(--text);border:1px solid var(--border);border-radius:8px;width:var(--map-control-size);min-width:var(--map-control-size);min-height:var(--map-control-size);padding:var(--map-control-padding-y) var(--map-control-padding-x);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;font-size:var(--map-control-font);font-weight:700;box-shadow:0 1px 4px var(--shadow);transition:background .12s,border-color .12s,transform .12s}.map-controls button:nth-child(3){width:var(--map-recenter-width);min-width:var(--map-recenter-width)}.map-controls button:hover{background:var(--panel);border-color:color-mix(in srgb,var(--accent) 44%,var(--border))}.map-controls button:active{transform:translateY(1px)}.route{font-weight:600;display:flex;flex-wrap:wrap;gap:8px 16px}.route-point{display:inline-flex;align-items:baseline;gap:4px;min-width:0;overflow-wrap:anywhere}.route-start{color:var(--accent-strong)}.route-target{color:var(--error)}.rule-line{line-height:1.35}.status{color:var(--muted);font-size:.98rem}.map{display:block;width:100%;height:100%}.outline{fill:none;stroke:var(--comarca-stroke);stroke-width:2.2;opacity:.8}.initials{pointer-events:none}.initial{fill:var(--text);font-weight:600;text-transform:uppercase;paint-order:stroke;stroke:#f8f4ece6;stroke-width:2.6px}.comarca{fill:var(--comarca-fill);stroke:var(--comarca-stroke);stroke-width:1.3;transition:fill .15s ease,stroke .15s ease,opacity .15s ease;cursor:default}.comarca.is-hidden{fill:transparent;stroke:transparent}.comarca.is-hidden.is-outline{fill:transparent;stroke:color-mix(in srgb,var(--text) 30%,transparent);stroke-width:1.4}.comarca.is-hidden.is-neighbor{fill:transparent;stroke:color-mix(in srgb,var(--text) 45%,transparent);stroke-width:2;stroke-dasharray:6 4}.comarca.is-hidden.is-hint{fill:#5c86c547;stroke:var(--accent-strong);stroke-width:2.2}.comarca.is-guessed{fill:var(--guess);animation:pop .35s ease;transform-box:fill-box;transform-origin:center}.comarca.is-start{fill:var(--accent-strong)}.comarca.is-target{fill:var(--error)}.comarca.is-current{stroke:var(--text);stroke-width:2.4}.comarca.is-complete-route{fill:color-mix(in srgb,var(--success) 58%,var(--comarca-fill));stroke:var(--success);stroke-width:2.4}.completion-celebrating .comarca.is-complete-route{animation:complete-route-pulse .52s ease both;transform-box:fill-box;transform-origin:center}.comarca.is-error{animation:flash .45s ease;stroke:var(--error);stroke-width:2.4}.comarca.is-neighbor{fill:transparent;stroke:color-mix(in srgb,var(--text) 45%,transparent);stroke-width:2;stroke-dasharray:6 4}.comarca.is-hint{fill:#5c86c547;stroke:var(--accent-strong);stroke-width:2.2}.comarca.is-replay{fill:#76b4b066;stroke:var(--accent);stroke-width:2.2}.comarca.is-reveal{fill:#c9a76a8c;stroke:var(--guess);stroke-width:2.2}.comarca.is-rule-reveal{fill:color-mix(in srgb,var(--accent) 34%,var(--panel));stroke:var(--accent);stroke-width:2.5}@keyframes flash{0%{fill:var(--error)}to{fill:var(--comarca-fill)}}@keyframes pop{0%{transform:scale(.92)}to{transform:scale(1)}}@keyframes complete-route-pulse{0%{opacity:.78;transform:scale(.98)}55%{opacity:1;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}.hint-buttons{display:grid;gap:10px}.mode-buttons{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.mode-buttons.two{grid-template-columns:repeat(2,minmax(0,1fr))}.mode-button{background:var(--surface);border:1px solid var(--border);border-radius:8px;min-height:var(--compact-button-min-height);padding:var(--compact-button-padding-y) var(--compact-button-padding-x);color:var(--text);cursor:pointer;text-align:center;font-size:var(--button-font);transition:background .12s}.mode-button.active{border-color:var(--accent);background:#76b4b01f}.mode-button.done{border-color:#3d8a5680;background:#3d8a5614}.difficulty-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.difficulty-button{display:grid;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:8px;min-height:var(--compact-button-min-height);padding:var(--compact-button-padding-y) var(--compact-button-padding-x);color:var(--text);cursor:pointer;text-align:left;font-size:var(--button-font);transition:background .12s}.difficulty-button.active{border-color:var(--accent);background:#76b4b01f}.difficulty-button.locked{opacity:.7}.difficulty-button:disabled{opacity:.45;cursor:default}.difficulty-button .price{color:var(--muted);font-size:.84rem}.level-select{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;min-height:var(--compact-button-min-height);padding:var(--compact-button-padding-y) var(--compact-button-padding-x);color:var(--text);font-size:var(--button-font);font-family:inherit}.toggle-button{justify-self:start;min-height:var(--compact-button-min-height);min-width:clamp(140px,14vw,164px);border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--muted);font-family:inherit;font-size:var(--button-font);font-weight:800;cursor:pointer}.toggle-button.active{background:var(--accent);border-color:var(--accent);color:#fff}.hint-button{background:var(--surface);border:1px solid var(--border);border-radius:10px;min-height:48px;padding:12px 14px;color:var(--text);cursor:pointer;text-align:left;transition:background .12s}.hint-button.active{border-color:var(--accent);background:#76b4b01f}.hint-button:disabled{opacity:.5;cursor:default}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--text) 42%,transparent);display:flex;align-items:center;justify-content:center;padding:max(24px,env(safe-area-inset-top)) max(24px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left));z-index:20;overflow:hidden}.modal{background:var(--panel);border-radius:8px;padding:28px;max-width:580px;width:min(580px,calc(100vw - 48px - env(safe-area-inset-left) - env(safe-area-inset-right)));max-height:calc(100vh - 48px - env(safe-area-inset-top) - env(safe-area-inset-bottom));max-height:calc(100svh - 48px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow-y:auto;overscroll-behavior:contain;display:grid;gap:16px;border:1px solid var(--border);box-shadow:0 8px 40px #1f2a3029}.options-modal{max-width:620px}.options-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:14px}.modal .path-list,.modal .shortest-list{max-height:140px}.modal h2{margin:0}.result-backdrop{background:color-mix(in srgb,var(--text) 34%,transparent)}.result-modal{max-width:760px;width:min(760px,calc(100vw - 48px - env(safe-area-inset-left) - env(safe-area-inset-right)));gap:18px;padding:18px}.result-hero{display:grid;gap:8px}.result-hero h2{font-size:1.78rem;line-height:1.12;letter-spacing:0}.result-score-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.result-score-pill{display:flex;align-items:center;justify-content:center;min-height:56px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:8px;background:color-mix(in srgb,var(--accent) 10%,var(--panel));color:var(--text);padding:11px 14px;font-weight:700;font-size:1rem;line-height:1.15;text-align:center}.result-learning{border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:12px 14px}.result-optimal{border-top:1px solid var(--border);padding-top:10px}.result-actions{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr)}.result-actions button{width:100%;min-width:0;white-space:normal;line-height:1.15}.result-primary{color:#fff;box-shadow:0 6px 16px color-mix(in srgb,var(--accent) 24%,transparent)}.modal-subtitle{margin:0;color:var(--muted);font-size:.98rem}.modal-section{display:grid;gap:8px}.tutorial-open-button{width:100%;min-height:var(--compact-button-min-height);border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);padding:var(--compact-button-padding-y) var(--compact-button-padding-x);font-family:inherit;font-size:var(--button-font);font-weight:750;cursor:pointer;text-align:center;transition:background .15s,border-color .15s,transform .12s}.tutorial-open-button:hover{background:color-mix(in srgb,var(--accent) 12%,var(--surface));border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.tutorial-open-button:active{transform:translateY(1px)}.tutorial-backdrop{background:color-mix(in srgb,var(--text) 48%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tutorial-modal{width:min(860px,100%);max-width:860px;padding:0;overflow:hidden;gap:0;animation:tutorial-enter .22s ease-out}.tutorial-shell{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);min-height:520px}.tutorial-visual{display:grid;place-items:center;padding:26px;background:linear-gradient(135deg,color-mix(in srgb,var(--surface) 94%,var(--accent)),var(--surface));border-right:1px solid var(--border)}.tutorial-copy{display:grid;grid-template-rows:auto auto 1fr auto;gap:20px;padding:26px}.tutorial-header,.tutorial-progress,.tutorial-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.tutorial-progress{color:var(--muted);font-weight:750}.tutorial-dots{display:flex;align-items:center;gap:8px}.tutorial-dot{width:12px;height:12px;border:1px solid color-mix(in srgb,var(--accent) 45%,var(--border));border-radius:999px;background:var(--surface);cursor:pointer;transition:background .15s,transform .15s,width .15s}.tutorial-dot.active{width:30px;background:var(--accent);border-color:var(--accent)}.tutorial-text{display:grid;align-content:start;gap:12px}.tutorial-text h2{margin:0;font-size:clamp(1.75rem,1.48rem + .9vw,2.25rem);line-height:1.06;letter-spacing:0}.tutorial-text p{margin:0;color:var(--muted);font-size:1.02rem;line-height:1.45}.tutorial-hint{border-left:3px solid var(--accent);padding-left:12px;color:var(--text)!important;font-weight:650}.tutorial-actions{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,.9fr) minmax(0,1.2fr)}.tutorial-actions button{width:100%;min-width:0;min-height:46px;display:inline-flex;align-items:center;justify-content:center;white-space:normal}.tutorial-shot{width:min(360px,100%);min-height:360px;border:1px solid var(--border);border-radius:8px;background:var(--panel);box-shadow:0 14px 34px #1f2a3024;color:var(--text);font-family:inherit;overflow:hidden}button.tutorial-shot{cursor:pointer;text-align:left}.tutorial-goal-shot{position:relative;display:grid;grid-template-rows:auto 1fr;gap:16px;padding:16px}.tutorial-route-card{display:grid;gap:8px;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--panel);box-shadow:0 4px 14px var(--shadow)}.tutorial-card-line{display:inline-flex;gap:5px;align-items:center;width:fit-content;border-radius:999px;padding:5px 9px;transition:background .18s,box-shadow .18s,transform .18s}.tutorial-card-start strong{color:var(--accent-strong)}.tutorial-card-target strong{color:var(--error)}.highlight-start .tutorial-card-start,.highlight-target .tutorial-card-target,.highlight-rule .tutorial-card-rule{background:color-mix(in srgb,var(--accent) 16%,var(--panel));box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 28%,transparent);transform:translate(4px)}.tutorial-mini-map{position:relative;min-height:210px;border-radius:8px;background:linear-gradient(145deg,color-mix(in srgb,var(--surface) 92%,var(--panel)),var(--surface));overflow:hidden}.tutorial-goal-map{display:block;width:100%;height:100%}.tutorial-goal-path{fill:color-mix(in srgb,var(--comarca-fill) 92%,var(--panel));stroke:color-mix(in srgb,var(--comarca-stroke) 92%,var(--panel));stroke-width:1.5;transition:fill .18s,stroke .18s,opacity .18s,filter .18s}.tutorial-goal-path.is-start{fill:color-mix(in srgb,var(--accent-strong) 58%,var(--comarca-fill));stroke:var(--accent-strong)}.tutorial-goal-path.is-rule{fill:color-mix(in srgb,var(--guess) 44%,var(--comarca-fill));stroke:var(--guess)}.tutorial-goal-path.is-target{fill:color-mix(in srgb,var(--error) 54%,var(--comarca-fill));stroke:var(--error)}.tutorial-goal-map.is-start .tutorial-goal-path.is-start,.tutorial-goal-map.is-target .tutorial-goal-path.is-target,.tutorial-goal-map.is-rule .tutorial-goal-path.is-rule{filter:drop-shadow(0 0 8px rgba(31,42,48,.18));stroke-width:3}.tutorial-goal-label text{font-size:22px;font-weight:800;fill:var(--text);stroke:var(--panel);stroke-width:5px;paint-order:stroke fill}.tutorial-goal-label circle{fill:currentColor}.tutorial-goal-label.is-start{color:var(--accent-strong)}.tutorial-goal-label.is-rule{color:var(--guess)}.tutorial-goal-label.is-target{color:var(--error)}.tutorial-goal-skeleton{display:grid;align-content:center;gap:12px;height:100%;padding:22px}.tutorial-goal-skeleton span{height:48px;border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--surface) 92%,var(--panel)),color-mix(in srgb,var(--panel) 75%,#fff),color-mix(in srgb,var(--surface) 92%,var(--panel)));background-size:220% 100%;animation:tutorial-skeleton 1.2s ease-in-out infinite}.mini-comarca{position:absolute;display:block;width:74px;height:62px;border:1px solid var(--comarca-stroke);background:var(--comarca-fill);transform:rotate(-10deg);clip-path:polygon(16% 8%,72% 2%,96% 35%,78% 88%,26% 96%,4% 55%)}.mini-start{left:44px;top:88px;background:var(--accent-strong);border-color:var(--accent-strong)}.mini-target{right:44px;top:78px;background:var(--error);border-color:var(--error)}.mini-mid.one{left:128px;top:50px}.mini-mid.two{left:156px;top:126px}.mini-route{position:absolute;left:88px;top:114px;width:174px;height:4px;border-radius:999px;background:color-mix(in srgb,var(--accent) 80%,#fff);transform:rotate(-4deg)}.tutorial-choose-shot,.tutorial-improve-shot{display:grid;align-content:start;gap:12px;padding:18px}.tutorial-improve-shot{width:min(420px,100%);min-height:auto;aspect-ratio:auto;border:none;background:transparent;box-shadow:none;padding:0}.tutorial-field-label{color:var(--muted);font-size:.76rem;font-weight:750;text-transform:uppercase}.tutorial-input{min-height:52px;border:1px solid var(--border);border-radius:8px;background:var(--surface);display:flex;align-items:center;padding:0 14px;font-weight:750}.tutorial-input i{width:2px;height:24px;margin-left:2px;background:var(--text);opacity:.7;animation:tutorial-caret 1s steps(2,end) infinite}.tutorial-suggestions{display:grid;gap:7px}.tutorial-suggestions span{min-height:38px;border-radius:8px;border:1px solid var(--border);background:var(--panel);display:flex;align-items:center;padding:0 12px;color:var(--muted);transition:background .18s,border-color .18s,transform .18s}.tutorial-suggestions .picked,.tutorial-choose-shot.is-played .tutorial-suggestions span:first-child{background:color-mix(in srgb,var(--accent) 16%,var(--panel));border-color:color-mix(in srgb,var(--accent) 50%,var(--border));color:var(--text);transform:translate(5px)}.tutorial-demo-button{min-height:44px;border:none;border-radius:8px;background:var(--accent);color:#fff;padding:10px 14px;font-family:inherit;font-weight:800;cursor:pointer;transition:background .15s,transform .12s,box-shadow .15s}.tutorial-demo-button:hover{background:var(--accent-hover);box-shadow:0 6px 16px color-mix(in srgb,var(--accent) 24%,transparent)}.tutorial-route-shot{display:grid;align-content:center;gap:24px;padding:22px}.tutorial-route-track{position:relative;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;align-items:center}.tutorial-route-track:before{content:"";position:absolute;left:8%;right:8%;top:50%;height:4px;border-radius:999px;background:var(--border);transform:translateY(-50%)}.tutorial-route-node{position:relative;z-index:1;display:grid;place-items:center;aspect-ratio:1;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:.78rem;font-weight:800;transition:background .18s,color .18s,transform .18s}.tutorial-route-node.is-active{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-4px)}.tutorial-route-node.is-start{background:var(--accent-strong);border-color:var(--accent-strong)}.tutorial-route-node.is-target.is-active{background:var(--error);border-color:var(--error)}.tutorial-route-status{justify-self:center;border:1px solid color-mix(in srgb,var(--accent) 38%,var(--border));border-radius:999px;background:color-mix(in srgb,var(--accent) 12%,var(--panel));padding:8px 12px;font-weight:800}.tutorial-result-card{display:grid;gap:12px;padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--panel)}.tutorial-result-title{margin:0;font-size:1.45rem;line-height:1.1;letter-spacing:0}.tutorial-result-subtitle{margin:0;color:var(--muted);font-size:.96rem}.tutorial-rule-card{display:grid;gap:6px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface) 88%,var(--panel))}.tutorial-rule-card p{margin:0;color:var(--text);font-size:.94rem;line-height:1.34}.tutorial-rule-card .is-reference{color:var(--muted)}.tutorial-score-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.tutorial-score-row span{min-height:40px;border-radius:8px;background:color-mix(in srgb,var(--accent) 10%,var(--surface));display:grid;place-items:center;text-align:center;font-size:.8rem;font-weight:800}.tutorial-route-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.tutorial-route-toggle button{min-height:42px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);font-family:inherit;font-weight:800;cursor:pointer;white-space:normal;line-height:1.15;text-align:center;padding:10px 12px;transition:background .15s,border-color .15s,color .15s}.tutorial-route-toggle button.active{background:var(--accent);border-color:var(--accent);color:#fff}.tutorial-route-caption{color:var(--text);font-size:.82rem;font-weight:800;text-transform:uppercase}.tutorial-result-list{counter-reset:route-item;list-style:none;margin:0;padding:14px;display:grid;gap:6px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted)}.tutorial-result-list li{counter-increment:route-item;display:grid;grid-template-columns:3ch minmax(0,1fr);gap:5px;align-items:baseline;min-width:0}.tutorial-result-list li:before{content:counter(route-item) ".";color:currentColor;font-variant-numeric:tabular-nums;text-align:right}.tutorial-result-list li.is-route-start{color:var(--accent-strong);font-weight:800}.tutorial-result-list li.is-route-target{color:var(--error);font-weight:800}.tutorial-result-list.is-optimal{border-color:color-mix(in srgb,var(--accent) 48%,var(--border));background:color-mix(in srgb,var(--accent) 9%,var(--surface))}.tutorial-result-actions{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:10px}.tutorial-result-actions button{width:100%;min-width:0;white-space:normal}.tutorial-result-actions button:disabled{opacity:1}.tutorial-result-actions .result-secondary:disabled{color:inherit}.tutorial-result-actions .reset:disabled{color:#fff}@keyframes tutorial-enter{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes tutorial-caret{0%,45%{opacity:.7}46%,to{opacity:0}}@keyframes tutorial-skeleton{0%{background-position:0% 50%}to{background-position:100% 50%}}.gauss-chart{display:grid;gap:6px}.gauss-path{fill:none;stroke:var(--accent);stroke-width:2}.gauss-marker{stroke:var(--accent-strong);stroke-width:2;stroke-dasharray:4 4}.gauss-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--muted)}@keyframes rain-shift{0%{background-position:0 0}to{background-position:-120px 240px}}@keyframes snow-fall{0%{background-position:0 -200px}to{background-position:0 200px}}@keyframes wind-shift{0%{background-position:0 0}to{background-position:120px 0}}@keyframes storm-flash{0%,to{opacity:.22}50%{opacity:.36}}.error-boundary{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--bg);padding:24px}.error-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px;width:min(420px,90vw);display:grid;gap:12px;box-shadow:0 4px 20px var(--shadow)}.error-card pre{background:color-mix(in srgb,var(--text) 5%,transparent);padding:10px;border-radius:10px;font-size:.75rem;color:var(--muted)}.bottom-nav{display:none}@media (min-width: 901px) and (max-width: 1080px){.brand-date{display:none}}@media (min-width: 901px) and (max-height: 720px){:root{--page-pad-top: clamp(10px, 1.8vh, 16px);--page-pad-bottom: clamp(10px, 2vh, 18px);--page-gap: clamp(10px, 1.6vh, 14px);--layout-gap: clamp(12px, 1.4vw, 18px)}.panel-card{padding:clamp(14px,2.2vh,18px);gap:clamp(9px,1.5vh,12px)}.side-panel{gap:clamp(10px,1.7vh,14px)}.map-wrap{padding:clamp(9px,1.7vh,12px);gap:clamp(8px,1.4vh,10px)}.prompt{padding:clamp(9px,1.6vh,12px) clamp(11px,1.5vw,15px);font-size:clamp(.94rem,1.8vh,1.06rem)}.brand-button{min-height:clamp(54px,9vh,62px)}.brand-logo{width:clamp(66px,10vh,76px);height:clamp(56px,8.5vh,64px);flex-basis:clamp(66px,10vh,76px)}.brand-logo-image{width:clamp(82px,13vh,92px);height:clamp(82px,13vh,92px)}h1{font-size:clamp(2.2rem,6vh,2.55rem)}.action-card,.options-card,.powerups{gap:clamp(9px,1.5vh,14px)}}@media (min-width: 901px) and (max-height: 540px){.side-panel{height:100%;max-height:100%;overflow-y:auto;overscroll-behavior:contain}}@media (max-width: 900px){body{font-size:17px;height:auto;overflow:auto}.page{padding:max(13px,env(safe-area-inset-top)) max(13px,env(safe-area-inset-right)) calc(82px + env(safe-area-inset-bottom)) max(13px,env(safe-area-inset-left));height:auto;min-height:100vh;min-height:100svh;overflow:visible}.topbar{display:grid;grid-template-columns:1fr;align-items:stretch;gap:8px;position:relative}.brand{display:block;width:100%;max-width:none;background:transparent;border:none;border-radius:0;box-shadow:none;padding:0}.brand-row{display:flex;justify-content:center}.brand-date{display:none}.brand-button{width:fit-content;max-width:100%;margin:0 auto;min-height:auto;padding:0;align-items:center;gap:10px;justify-content:center;text-align:center}.brand h1{font-size:2.18rem;line-height:1}.brand-logo{width:62px;height:54px;flex-basis:62px}.brand-logo-image{width:76px;height:76px}.topbar-right{display:none}.topbar-actions{display:none;flex-direction:row;gap:6px;grid-template-columns:unset;grid-template-areas:unset;background:color-mix(in srgb,var(--text) 7%,transparent);border-radius:8px;padding:4px;width:100%;justify-items:unset}.topbar-button.topbar-new-game,.topbar-challenge,.calendar-icon-button.topbar-calendar,.streak-card.topbar-streak{display:none}.status-stack{justify-items:center}.calendar-overlay{padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));justify-content:center;align-items:flex-end}.calendar-panel{width:calc(100vw - 32px - env(safe-area-inset-left) - env(safe-area-inset-right));max-width:none;border-radius:8px 8px 0 0;height:min(86vh,660px);height:min(86svh,660px);max-height:calc(100vh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom));max-height:calc(100svh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom));padding:clamp(12px,3.5vw,18px)}.stats{grid-template-columns:1fr}.mode-buttons{grid-template-columns:repeat(2,minmax(0,1fr))}.difficulty-grid,.options-audio-controls{grid-template-columns:1fr}.scope-buttons{grid-template-columns:repeat(2,minmax(0,1fr))}.group-row{grid-template-columns:1fr}.game-layout{grid-template-columns:1fr;gap:14px;height:auto;overflow:visible}.map-wrap{height:clamp(320px,74vw,450px);min-height:min(340px,calc(100svh - 150px));max-height:450px;border-radius:8px;gap:8px}.prompt{padding:9px;font-size:.88rem;gap:5px}.route{display:grid;gap:3px}.route-point{display:flex;gap:3px;min-width:0}.rule-line{font-size:.8rem;line-height:1.25}.map-controls{--map-control-size: clamp(38px, 10.2vw, 42px);--map-recenter-width: clamp(76px, 20vw, 84px);--map-control-gap: clamp(5px, 1.7vw, 7px);--map-control-font: clamp(.76rem, 2.15vw, .84rem);--map-control-padding-y: clamp(6px, 1.8vw, 8px);--map-control-padding-x: clamp(8px, 2.2vw, 10px);top:auto;right:clamp(10px,3vw,12px);bottom:clamp(10px,3vw,12px)}.side-panel{height:auto;max-height:none;overflow:visible;padding-right:0}.panel-card{padding:16px 18px;border-radius:8px}.submit{border-radius:8px;min-height:46px;padding:10px 12px}.options-launch-button{display:none}.modal-backdrop{padding:max(14px,env(safe-area-inset-top)) max(14px,env(safe-area-inset-right)) max(14px,env(safe-area-inset-bottom)) max(14px,env(safe-area-inset-left))}.tutorial-backdrop{align-items:stretch;padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.tutorial-modal{width:calc(100vw - 20px - env(safe-area-inset-left) - env(safe-area-inset-right));max-width:none;height:calc(100dvh - 20px);height:calc(100svh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom));max-height:calc(100dvh - 20px);max-height:calc(100svh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom));border-radius:14px}.tutorial-shell{grid-template-columns:1fr;grid-template-rows:minmax(260px,42%) minmax(0,1fr);height:100%;min-height:0}.tutorial-modal.tutorial-step-goal .tutorial-shell{grid-template-rows:minmax(320px,48%) minmax(0,1fr)}.tutorial-modal.tutorial-step-choose .tutorial-shell{grid-template-rows:minmax(330px,50%) minmax(0,1fr)}.tutorial-modal.tutorial-step-improve .tutorial-shell{grid-template-rows:minmax(380px,56%) minmax(0,1fr)}.tutorial-visual{min-height:0;padding:12px 12px 10px;border-right:none;border-bottom:1px solid var(--border);overflow:hidden}.tutorial-copy{min-height:0;gap:12px;padding:16px;overflow:hidden}.tutorial-shot{width:min(318px,100%);max-width:100%;max-height:100%;min-height:0;aspect-ratio:1.08}.tutorial-goal-shot{width:min(318px,100%);height:100%;aspect-ratio:auto;grid-template-rows:auto minmax(0,1fr);gap:12px;padding:12px}.tutorial-goal-shot .tutorial-route-card{gap:6px;padding:10px}.tutorial-goal-shot .tutorial-card-line{padding:4px 8px}.tutorial-mini-map{min-height:0;height:100%}.tutorial-goal-label text{font-size:14px;stroke-width:3px}.tutorial-choose-shot{width:min(318px,100%);height:100%;max-height:100%;aspect-ratio:auto;align-content:stretch;grid-template-rows:auto auto minmax(0,1fr) auto;gap:8px;padding:12px;overflow-y:auto}.tutorial-choose-shot .tutorial-field-label{font-size:.68rem}.tutorial-choose-shot .tutorial-input{min-height:46px;padding:0 12px}.tutorial-choose-shot .tutorial-suggestions{gap:6px;align-content:start}.tutorial-choose-shot .tutorial-suggestions span{min-height:34px;padding:0 10px}.tutorial-choose-shot .tutorial-demo-button{min-height:42px;padding:9px 12px}.tutorial-text h2{font-size:1.52rem}.tutorial-text p{font-size:.93rem;line-height:1.34}.tutorial-text{min-height:0;overflow-y:auto;padding-right:2px}.tutorial-progress{align-items:flex-start;flex-wrap:wrap}.tutorial-actions{grid-template-columns:1fr;gap:8px;margin-top:auto;padding-top:10px;background:linear-gradient(180deg,rgba(255,252,245,0),var(--panel) 24%)}.tutorial-score-row{grid-template-columns:1fr}.tutorial-improve-shot{width:min(318px,100%);height:100%;max-height:100%;overflow-y:auto;padding-right:2px}.tutorial-improve-shot .tutorial-result-card{gap:8px;padding:12px}.tutorial-improve-shot .tutorial-result-title{font-size:1.28rem}.tutorial-improve-shot .tutorial-result-subtitle,.tutorial-improve-shot .tutorial-rule-card p{font-size:.84rem}.tutorial-improve-shot .tutorial-score-row span{min-height:36px}.result-modal{width:calc(100vw - 28px - env(safe-area-inset-left) - env(safe-area-inset-right));max-width:none;max-height:calc(100vh - 96px - env(safe-area-inset-top) - env(safe-area-inset-bottom));max-height:calc(100svh - 96px - env(safe-area-inset-top) - env(safe-area-inset-bottom));padding:14px}.tutorial-route-toggle,.tutorial-result-actions{grid-template-columns:1fr}.tutorial-result-card{gap:10px;padding:14px}.tutorial-result-list{padding:12px 12px 12px 24px}.result-score-row{grid-template-columns:1fr}.result-score-pill{justify-content:flex-start;text-align:left}.result-actions{grid-template-columns:1fr;position:sticky;bottom:0;background:var(--panel);padding-top:8px}.ranking-lists{grid-template-columns:1fr}.bottom-nav{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:6px;position:fixed;bottom:0;left:0;right:0;min-height:62px;padding:7px 9px calc(7px + env(safe-area-inset-bottom));background:var(--panel);border-top:1px solid var(--border);box-shadow:0 -2px 12px var(--shadow);z-index:10}.bottom-nav-item{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:0;min-width:0;min-height:clamp(38px,9.5vw,42px);border:1px solid transparent;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;padding:0 clamp(3px,1.2vw,5px);font-family:inherit;transition:border-color .15s,color .15s,background .15s}.bottom-nav-item.active{background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:color-mix(in srgb,var(--accent) 26%,transparent);color:var(--accent)}.bottom-nav-new-game{display:flex;align-items:center;justify-content:center;min-width:clamp(98px,29vw,118px);min-height:clamp(42px,10.8vw,46px);border:1px solid color-mix(in srgb,var(--accent) 70%,var(--stroke));border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;padding:clamp(7px,2.2vw,10px) clamp(9px,2.8vw,12px);font-family:inherit;box-shadow:0 6px 16px color-mix(in srgb,var(--accent) 24%,transparent);transition:background .15s,border-color .15s,transform .15s}.bottom-nav-new-game:active{transform:translateY(1px)}.bottom-nav-new-game:disabled,.bottom-nav-item:disabled{cursor:not-allowed;opacity:.55}.bottom-nav-icon{display:none}.bottom-nav-label{min-width:0;max-width:100%;font-size:clamp(.64rem,2.1vw,.74rem);font-weight:650;letter-spacing:0;line-height:1.08;overflow-wrap:anywhere;text-align:center;white-space:normal}.bottom-nav-new-game .bottom-nav-label{font-size:clamp(.68rem,2.25vw,.82rem);font-weight:750}html.mobile-keyboard-open .page{padding-bottom:max(13px,env(safe-area-inset-bottom))}html.mobile-keyboard-open .bottom-nav{position:static;left:auto;right:auto;bottom:auto;width:100%;margin-top:12px;transform:none}}@media (max-width: 900px) and (max-height: 520px){.page{padding-top:max(9px,env(safe-area-inset-top))}.topbar{gap:6px}.brand h1{font-size:clamp(1.78rem,7.5vh,2.05rem)}.brand-logo{width:clamp(50px,13vh,58px);height:clamp(44px,11vh,50px);flex-basis:clamp(50px,13vh,58px)}.brand-logo-image{width:clamp(64px,17vh,72px);height:clamp(64px,17vh,72px)}.map-wrap{height:clamp(250px,calc(100svh - 128px),330px);min-height:250px}.calendar-overlay{align-items:center}.calendar-panel{border-radius:8px;height:calc(100svh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom));max-height:calc(100svh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}.calendar-day{min-height:42px;gap:3px}.modal{padding:18px}.result-modal{max-height:calc(100svh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}body.aula-route{height:auto;min-height:100vh;overflow:auto;background:#f6f4ee}body.aula-route:before{display:none}html.aristocracia-route{height:auto;min-height:100%;overflow-y:auto;overflow-x:hidden}html.aristocracia-route #root{height:auto;min-height:100vh;min-height:100dvh;overflow:visible}html.aristocracia-route body,body.aristocracia-route{height:auto;min-height:100vh;min-height:100dvh;overflow-y:auto;overflow-x:hidden;position:static;background:linear-gradient(180deg,rgba(47,111,117,.08),transparent 320px),#f4f5f1}html.aristocracia-route body{-webkit-overflow-scrolling:touch}body.aristocracia-route:before{display:none}.aula-shell{--aula-bg: #f6f4ee;--aula-surface: #fffdf8;--aula-surface-2: #ece7dd;--aula-text: #1f2a30;--aula-muted: #627177;--aula-border: #d7ccbb;--aula-accent: #2f6f75;--aula-accent-2: #315d9a;--aula-danger: #ba3d34;width:min(1160px,calc(100% - 32px));margin:0 auto;padding:18px 0 42px;color:var(--aula-text)}.aula-shell-wide{width:min(1360px,calc(100% - 32px))}.aula-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:18px;align-items:center;min-height:72px;border-bottom:1px solid var(--aula-border)}.aula-brand{display:inline-flex;align-items:center;gap:10px;color:inherit;text-decoration:none}.aula-brand-mark{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:var(--aula-accent);color:#fff;font-weight:800}.aula-brand strong,.aula-brand small{display:block;line-height:1.1}.aula-brand small{color:var(--aula-muted);font-size:.82rem}.aula-nav{display:flex;flex-wrap:wrap;gap:8px 14px;justify-content:center}.aula-nav a,.aula-link-button,.aula-table a{color:var(--aula-accent-2);font-weight:700;text-decoration:none}.aula-link-button{border:none;background:transparent;cursor:pointer;font:inherit}.aula-main{display:grid;gap:22px;padding-top:28px}.aula-hero,.aula-panel-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:end}.aula-hero h1,.aula-panel-head h1,.aula-card h1{margin:0;font-size:clamp(2.2rem,7vw,5.5rem);line-height:.95;letter-spacing:0}.aula-panel-head h1,.aula-card h1{font-size:clamp(2rem,4vw,3.2rem)}.aula-hero-copy{max-width:720px;margin:18px 0 0;color:var(--aula-muted);font-size:1.24rem;line-height:1.45}.aula-hero-panel{width:min(360px,100%);border-left:4px solid var(--aula-accent);background:var(--aula-surface);padding:18px;display:grid;gap:8px;box-shadow:0 1px 4px #1f2a3014}.aula-eyebrow{margin:0 0 8px;color:var(--aula-muted);font-size:.76rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.aula-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:20px}.aula-button{min-height:44px;border:1px solid transparent;border-radius:8px;padding:10px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-weight:800;text-decoration:none;cursor:pointer}.aula-button-primary{background:var(--aula-accent);color:#fff}.aula-button-secondary{background:var(--aula-surface);color:var(--aula-text);border-color:var(--aula-border)}.aula-button:disabled{opacity:.55;cursor:not-allowed}.aula-grid{display:grid;gap:18px}.aula-grid-two{grid-template-columns:repeat(2,minmax(0,1fr))}.aula-grid-four{grid-template-columns:repeat(4,minmax(0,1fr))}.aula-card,.aula-mini-card{background:var(--aula-surface);border:1px solid var(--aula-border);border-radius:8px;padding:22px;box-shadow:0 1px 5px #1f2a3014}.aula-card h2,.aula-mini-card h3{margin:0 0 10px;font-size:1.35rem;line-height:1.18}.aula-card p,.aula-panel-head p,.aula-muted-line{color:var(--aula-muted);line-height:1.45}.aula-material{margin:14px 0}.aula-material summary{cursor:pointer;font-weight:700;color:var(--aula-accent)}.aula-material pre{max-height:320px;overflow:auto;white-space:pre-wrap;border:1px solid var(--aula-border);border-radius:8px;padding:14px;background:var(--aula-surface-2);color:var(--aula-text);font:.92rem/1.45 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.aula-number-list{display:grid;gap:10px;margin:0;padding-left:1.4rem}.aula-chip-list{display:flex;flex-wrap:wrap;gap:8px}.aula-chip-list span{border:1px solid var(--aula-border);border-radius:999px;padding:7px 11px;background:var(--aula-surface-2)}.aula-narrow{width:min(560px,100%);margin:0 auto}.aula-form{display:grid;gap:14px}.aula-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.aula-field-wide{grid-column:1 / -1}.aula-form label{display:grid;gap:6px;color:var(--aula-text);font-weight:700}.aula-form input,.aula-form select,.aula-form textarea{width:100%;min-height:44px;border:1px solid var(--aula-border);border-radius:8px;background:#fff;color:var(--aula-text);padding:10px 12px;font:inherit}.aula-check{grid-template-columns:auto minmax(0,1fr)!important;align-items:center}.aula-check input{width:auto;min-height:auto}.aula-message{border:1px solid var(--aula-border);border-radius:8px;padding:11px 13px;background:var(--aula-surface);color:var(--aula-text)}.aula-message-error{border-color:#ba3d346b;color:var(--aula-danger)}.aula-message-ok{border-color:#2f6f756b;color:var(--aula-accent)}.aula-loading{display:inline-flex;align-items:center;gap:10px;color:var(--aula-muted)}.aula-spinner{width:18px;height:18px;border:2px solid var(--aula-border);border-top-color:var(--aula-accent);border-radius:50%;animation:aula-spin .8s linear infinite}@keyframes aula-spin{to{transform:rotate(360deg)}}.aula-section-title{display:flex;align-items:center;justify-content:space-between;gap:14px}.aula-empty{color:var(--aula-muted)}.aula-table-wrap{overflow-x:auto}.aula-table{width:100%;border-collapse:collapse;min-width:720px}.aula-table-compact{min-width:560px}.aula-table th,.aula-table td{border-bottom:1px solid var(--aula-border);padding:10px 9px;text-align:left;vertical-align:top}.aula-table th{color:var(--aula-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}.aula-table-actions{display:flex;flex-wrap:wrap;gap:6px}.aula-table-actions button{border:1px solid var(--aula-border);border-radius:8px;background:#fff;padding:7px 9px;font:inherit;cursor:pointer}.aula-projector-card{min-height:calc(100vh - 160px);align-content:center}.aula-projector-card h1{font-size:clamp(2.4rem,7vw,6rem)}.aula-projector-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:24px 0}.aula-projector-grid div,.aula-solution{border:1px solid var(--aula-border);border-radius:8px;background:var(--aula-surface-2);padding:16px}.aula-projector-grid span,.aula-projector-grid strong{display:block}.aula-projector-grid strong{font-size:1.4rem}.aula-projector-live{display:grid;grid-template-columns:minmax(220px,.42fr) minmax(0,1fr);gap:18px;align-items:start;margin:20px 0}.aula-qr{width:180px;height:180px;border:1px solid var(--aula-border);border-radius:8px;background:#fff}.aula-ranking{display:grid;gap:8px;margin:0;padding-left:1.4rem}.aula-ranking li{padding:9px 0;border-bottom:1px solid var(--aula-border)}.aula-ranking strong,.aula-ranking span{display:block}.aula-level-builder{align-items:start}.aula-preview-card{overflow:hidden}.aula-preview-frame{height:min(760px,82vh);min-height:520px;border:1px solid var(--aula-border);border-radius:8px;overflow:hidden;background:var(--bg)}.aula-preview-frame .aula-play,.aula-preview-frame .page{min-height:100%;height:100%}.aula-play{min-height:100vh;background:var(--bg)}.aula-play-bar{min-height:54px;display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--panel);color:var(--text);position:relative;z-index:20}.aula-play-bar a{margin-left:auto;color:var(--accent-strong);font-weight:800;text-decoration:none}.aula-play .page{min-height:calc(100vh - 54px);height:calc(100vh - 54px)}.aula-play .aula-game-page{grid-template-rows:1fr;padding-top:14px}.aula-play .topbar,.aula-play .bottom-nav,.aula-play .options-launch-button{display:none!important}.aristocracia-shell{--aula-bg: #f4f5f1;--aula-surface: #fffef9;--aula-surface-2: #eef2ea;--aula-border: #d8dfd2;--aula-accent: #245f63;--aula-accent-2: #2f5f8f;width:min(1440px,calc(100% - 32px));padding-bottom:72px}.aristocracia-shell .aula-header{position:sticky;top:0;z-index:30;min-height:70px;margin:0 -2px;padding:10px 2px;border-color:#141c231f;background:color-mix(in srgb,#f4f5f1 88%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.aristocracia-shell .aula-main{gap:20px;padding-top:22px;padding-bottom:48px}.aristocracia-shell .aula-brand-mark{background:linear-gradient(135deg,#1f4f52,#2f6f75)}.aristocracia-shell .aula-nav{gap:8px}.aristocracia-shell .aula-header-actions{display:inline-flex;align-items:center;justify-content:flex-end;gap:10px}.aristocracia-role-pill,.aristocracia-tab,.aristocracia-status-badge{border-radius:999px;white-space:nowrap}.aristocracia-role-pill{border:1px solid rgba(47,111,117,.24);background:#fff;color:var(--aula-accent);padding:7px 10px;font-size:.82rem;font-weight:800}.aristocracia-tab{border:1px solid transparent;background:transparent;color:var(--aula-muted);padding:9px 12px;font:inherit;font-size:.94rem;font-weight:800;cursor:pointer}.aristocracia-tab:hover,.aristocracia-tab:focus-visible{background:#2f6f7514;color:var(--aula-accent)}.aristocracia-tab.is-active{background:var(--aula-accent);border-color:var(--aula-accent);color:#fff}.aristocracia-auth-card{margin-top:min(8vh,72px)}.aristocracia-hero{align-items:center;border-bottom:1px solid var(--aula-border);padding-bottom:18px}.aristocracia-hero h1{font-size:clamp(2.4rem,5vw,4.4rem)}.aristocracia-dashboard{align-items:start}.aristocracia-metrics{gap:14px}.aristocracia-metric-card{display:grid;gap:6px;min-height:142px;border-top:4px solid transparent}.aristocracia-metric-card.tone-good{border-top-color:var(--aula-accent)}.aristocracia-metric-card.tone-warning{border-top-color:#b2771c}.aristocracia-metric-card.tone-neutral{border-top-color:var(--aula-accent-2)}.aristocracia-metric-card strong{display:block;color:var(--aula-text);font-size:clamp(2rem,4vw,3rem);line-height:.95}.aristocracia-metric-card span{color:var(--aula-muted);line-height:1.35}.aristocracia-panel-card{min-width:0}.aristocracia-table-card{overflow:hidden}.aristocracia-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.aristocracia-section-header h2{margin:0 0 6px;font-size:clamp(1.35rem,2vw,1.8rem)}.aristocracia-section-header p{margin:0}.aristocracia-section-actions{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.aristocracia-status-list,.aristocracia-license-list{display:grid;gap:10px}.aristocracia-status-row,.aristocracia-license-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--aula-border);border-radius:8px;padding:12px;background:var(--aula-surface-2);min-width:0}.aristocracia-status-row>div,.aristocracia-license-item>div{min-width:0}.aristocracia-status-row strong,.aristocracia-status-row span,.aristocracia-license-item strong,.aristocracia-license-item span{display:block}.aristocracia-status-row strong,.aristocracia-license-item strong{overflow-wrap:anywhere}.aristocracia-status-row span:not(.aristocracia-status-badge),.aristocracia-license-item span:not(.aristocracia-status-badge){color:var(--aula-muted);font-size:.94rem;line-height:1.35}.aristocracia-status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:96px;border:1px solid var(--aula-border);padding:6px 10px;background:#fff;color:var(--aula-text);font-size:.84rem;font-weight:800}.aristocracia-status-badge.status-online{border-color:#2f6f7557;background:#2f6f7514;color:var(--aula-accent)}.aristocracia-status-badge.status-degraded{border-color:#b2771c57;background:#b2771c1a;color:#945900}.aristocracia-status-badge.status-offline{border-color:#ba3d3457;background:#ba3d3414;color:var(--aula-danger)}.aristocracia-status-badge.status-unknown{color:var(--aula-muted)}.aristocracia-social-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.aristocracia-social-grid .aula-mini-card,.aristocracia-social-card{display:grid;gap:12px}.aristocracia-social-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.aristocracia-social-grid label{display:grid;gap:6px;font-weight:700}.aristocracia-social-grid input,.aristocracia-social-grid select{width:100%;min-height:42px;border:1px solid var(--aula-border);border-radius:8px;padding:9px 10px;font:inherit}.aristocracia-editor-grid{align-items:start}.aristocracia-floating-message{margin:0}.aristocracia-shell .aula-table-wrap{max-width:100%;overflow-x:auto;overscroll-behavior-x:contain}.aristocracia-shell .aula-table{font-size:.94rem}.aristocracia-shell .aula-table th,.aristocracia-shell .aula-table td{white-space:nowrap}.aristocracia-shell .aula-table td:first-child,.aristocracia-shell .aula-table th:first-child{position:sticky;left:0;z-index:1;background:var(--aula-surface);white-space:normal;min-width:180px}@media (max-width: 980px){.aristocracia-shell .aula-header{grid-template-columns:1fr;align-items:start}.aristocracia-shell .aula-nav{justify-content:flex-start;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.aristocracia-shell .aula-header-actions{justify-content:flex-start}.aristocracia-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.aula-shell{width:min(100% - 22px,1160px);padding-top:10px}.aula-header,.aula-hero,.aula-panel-head,.aula-grid-two,.aula-grid-four,.aula-form-grid,.aula-projector-grid,.aula-projector-live{grid-template-columns:1fr}.aula-nav{justify-content:flex-start}.aula-header-actions{justify-self:start}.aristocracia-shell{width:min(100% - 20px,1160px);padding-bottom:48px}.aristocracia-shell .aula-header{position:relative;padding-bottom:12px}.aristocracia-shell .aula-nav{flex-wrap:nowrap;margin-inline:-2px}.aristocracia-tab{flex:0 0 auto}.aristocracia-metrics{grid-template-columns:1fr}.aristocracia-section-header{display:grid}.aristocracia-section-actions{justify-content:flex-start}.aristocracia-status-row,.aristocracia-license-item{align-items:flex-start;flex-direction:column}.aristocracia-social-grid{grid-template-columns:1fr}.aula-hero h1{font-size:clamp(2.5rem,16vw,4rem)}.aula-play .page{height:auto;min-height:calc(100vh - 54px)}}
