:root{--bg-color:#2c3e50;--surface-color:#34495e;--primary-color:#3498db;--primary-hover:#2980b9;--secondary-color:#e67e22;--text-color:#ecf0f1;--border-color:#22303f;--invalid-color:#e74c3c;--correct-color:#2ecc71;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--white-gem:#fff;--yellow-gem:#f1c40f;--red-gem:#e74c3c;--blue-gem:#3498db;--transparent-gem-stroke:#bdc3c7;--black-gem:#2c3a47}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-color);overscroll-behavior:none;-webkit-font-smoothing:antialiased}#app{background-color:var(--surface-color);flex-direction:column;max-width:550px;height:100vh;max-height:100vh;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 0 20px #00000080}.screen{background:url(https://www.transparenttextures.com/patterns/low-contrast-linen.png), var(--bg-color);opacity:1;flex-direction:column;align-items:center;width:100%;height:100%;padding:1.5rem;transition:opacity .3s ease-in-out,transform .3s ease-in-out;display:flex;position:absolute;top:0;left:0;transform:scale(1)}#screen-main,#screen-custom-creator{overflow-y:auto}.screen.hidden{visibility:hidden;opacity:0;pointer-events:none;transform:scale(.95)}.screen-v-center{justify-content:center}.screen-content{text-align:center;flex-direction:column;align-items:center;gap:1rem;width:100%;display:flex}#lang-switcher{cursor:pointer;-webkit-tap-highlight-color:transparent;background-color:#0003;border-radius:8px;justify-content:center;align-items:center;width:50px;height:50px;transition:background-color .2s;display:flex;position:absolute;top:15px;right:15px}#lang-switcher:hover{background-color:#0006}#lang-switcher svg{width:32px;height:auto;display:block}.title{letter-spacing:2px;text-shadow:2px 2px 4px #0000004d;margin-top:1rem;margin-bottom:.5rem;font-size:3rem;font-weight:300}.subtitle-group{text-align:center;margin-top:-1rem;margin-bottom:2rem}.byline,.based-on{color:#ffffffb3;font-size:.9rem;font-weight:300;line-height:1.4}.byline{margin-bottom:.1rem}.based-on a{color:inherit;text-decoration:underline;-webkit-text-decoration-color:var(--primary-color);text-decoration-color:var(--primary-color);transition:color .2s,text-decoration-color .2s}.based-on a:hover{color:var(--primary-hover);-webkit-text-decoration-color:var(--primary-hover);text-decoration-color:var(--primary-hover)}.version-info{text-align:center;color:#ecf0f1b3;text-shadow:0 1px 3px #0009;pointer-events:none;width:100%;margin-top:1.5rem;padding-bottom:1rem;font-size:.75rem}.subtitle{margin-bottom:0;font-size:2rem;font-weight:400}.menu-buttons button{background-color:var(--primary-color);color:var(--text-color);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:center;border:none;border-radius:8px;min-width:200px;margin:.5rem;padding:.8rem 1.5rem;font-size:1.2rem;font-weight:500;transition:all .2s;box-shadow:0 4px 6px #0003}.menu-buttons button:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 8px #00000040}.menu-buttons button:disabled{color:#bdc3c7;cursor:not-allowed;background-color:#7f8c8d;border-color:#95a5a6;transform:none;box-shadow:0 2px 3px #00000026}.menu-buttons.vertical{flex-direction:column;align-items:center;display:flex}.menu-buttons .btn-back{border:2px solid var(--primary-color);color:var(--primary-color);box-shadow:none;background-color:#0000;margin-top:2rem;padding:calc(.8rem - 2px) calc(1.5rem - 2px)}.menu-buttons .btn-back:hover{background-color:var(--primary-hover);color:var(--text-color);border-color:var(--primary-hover)}#screen-difficulty .subtitle{margin-top:1rem;margin-bottom:2rem}#screen-difficulty>.screen-content{flex-grow:1}#screen-difficulty>.menu-buttons{text-align:center;padding-top:1rem}#screen-difficulty>.menu-buttons .btn-back{margin-top:0}#difficulty-options .difficulty-desc{color:#ffffffb3;max-width:300px;margin-top:.25rem;margin-left:auto;margin-right:auto;font-size:.9rem;font-weight:300}#intro-rules{border:1px solid var(--border-color);text-align:left;background-color:#0003;border-radius:8px;width:100%;max-width:500px;margin-top:2rem;padding:1rem .8rem}#intro-rules p,#intro-rules ul{font-size:.95rem;line-height:1.6}#intro-rules ul{margin:.5rem 0;padding-left:1.2rem}#intro-rules ul li ul{margin-top:.5rem;margin-bottom:.5rem;padding-left:1rem}#intro-rules strong{color:var(--primary-color)}#intro-rules h3{margin-top:.5rem;margin-bottom:.25rem;font-weight:600}#intro-rules h4{border-bottom:1px solid var(--border-color);margin-top:1rem;margin-bottom:.5rem;padding-bottom:.25rem;font-weight:600}.rules-details{border:1px solid var(--border-color);border-radius:6px;margin-top:1rem;transition:background-color .2s}#intro-rules>.rules-details:first-child{border:none;margin-top:0}.rules-summary{cursor:pointer;padding:.75rem 0;font-weight:600;list-style:none;position:relative}.rules-summary:hover{background-color:#ffffff0d}.rules-summary::-webkit-details-marker{display:none}.rules-summary h3{border:none;margin:0;padding:0;font-size:1.15rem;font-weight:600;display:inline-block}.rules-summary h4{border:none;margin:0;padding:0;font-size:1rem;font-weight:600;display:inline-block}.rules-summary:after{content:"▶";color:var(--primary-color);font-size:.8em;transition:transform .2s ease-in-out;position:absolute;top:50%;right:.25rem;transform:translateY(-50%)rotate(0)}.rules-details[open]>.rules-summary:after{transform:translateY(-50%)rotate(90deg)}.rules-details .details-content{border-top:1px solid var(--border-color);padding:0 0 1rem;animation:.3s ease-out fadeInDetails}@keyframes fadeInDetails{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-content p{margin-bottom:.5rem;line-height:1.6}.custom-creator-layout{flex-grow:1;width:100%}.custom-creator-layout h4{color:var(--primary-color);border-bottom:1px solid var(--border-color);text-align:left;margin-bottom:.5rem;padding-bottom:.5rem;font-weight:500}.creator-main-content{flex-direction:column;gap:1.5rem;width:100%;margin:1rem 0;display:flex}.creator-config,.creator-preview{background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.selector-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.color-choice{aspect-ratio:1;cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;border-radius:6px;width:100%;transition:all .2s}.color-choice:hover{transform:scale(1.05)}.color-choice.selected{border-color:var(--secondary-color);box-shadow:0 0 10px var(--secondary-color)}.shape-choice{aspect-ratio:1;cursor:pointer;border:2px solid var(--border-color);background-color:var(--bg-color);-webkit-tap-highlight-color:transparent;border-radius:6px;width:100%;padding:4px;transition:all .2s}.shape-choice canvas{pointer-events:none;width:100%;height:100%}.shape-choice:hover{background-color:#4a627a;transform:scale(1.05)}.shape-choice.selected{border-color:var(--secondary-color);box-shadow:0 0 10px var(--secondary-color);background-color:#526f8c}.shape-choice-add{border-style:dashed;border-color:var(--primary-color)}.shape-choice-add:hover{border-style:solid;border-color:var(--primary-hover)}.shape-choice-add.selected{border-style:solid}.add-gem-button{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;margin-top:1rem;padding:.8rem;font-size:1.1rem;transition:all .2s}.add-gem-button:hover{background:var(--primary-hover)}#custom-gem-list{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));align-content:flex-start;gap:.75rem;min-height:80px;padding-bottom:1rem;display:grid}.custom-gem-item{border:1px solid var(--border-color);background:var(--bg-color);border-radius:4px;padding:4px;animation:.3s fadeIn;position:relative}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.custom-gem-item canvas{width:100%;height:100%}.delete-gem-btn{background:var(--invalid-color);color:#fff;border:1px solid var(--text-color);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:14px;font-weight:700;line-height:1;display:flex;position:absolute;top:-8px;right:-8px}.delete-gem-btn:hover{background:#c0392b}#custom-validation-feedback{border:1px solid var(--border-color);text-align:center;background-color:#0003;border-radius:6px;justify-content:center;align-items:center;min-height:38px;margin-top:1rem;padding:.6rem;font-size:.9rem;line-height:1.4;display:flex}#custom-validation-feedback div{margin-bottom:0}#custom-validation-feedback .valid{color:var(--correct-color)}#custom-validation-feedback .invalid{color:var(--invalid-color)}#custom-validation-feedback strong{font-weight:600}#screen-game{background:var(--surface-color);justify-content:flex-start;padding:0;overflow:hidden}#game-container{flex-grow:1;justify-content:center;align-items:center;width:100%;min-height:350px;padding:1rem;display:flex;position:relative;overflow-y:auto}#game-board-wrapper{aspect-ratio:10/12;width:100%;max-width:450px;margin:auto;position:relative}#gem-canvas,#path-overlay{width:100%;height:100%;position:absolute;top:0;left:0}#gem-canvas{z-index:1}#gem-canvas:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:2px}#path-overlay{z-index:100;pointer-events:none}#screen-end{justify-content:flex-start;overflow:hidden}.end-content-container{flex-direction:column;flex-grow:1;align-items:center;gap:.5rem;width:100%;min-height:0;padding:0 .5rem;display:flex;overflow:auto}#end-title.win{color:var(--correct-color)}#end-title.loss{color:var(--invalid-color)}#end-rating{color:var(--secondary-color);text-align:center;margin:.25rem 0;font-size:1.4rem;font-weight:500}#end-stats{margin-bottom:.5rem}#end-solution-wrapper{border:2px solid var(--bg-color);flex-direction:column;margin:.5rem 0;padding:5px;display:flex}#end-solution-wrapper>p{flex-shrink:0;margin-bottom:5px;font-size:.9rem}#end-solution-canvas{min-height:0;image-rendering:-moz-crisp-edges;image-rendering:-webkit-crisp-edges;image-rendering:pixelated;image-rendering:crisp-edges}#end-main-row{flex-direction:column;align-items:center;width:100%;display:flex}#end-rating-legend{color:#ffffffb3;border:1px solid var(--border-color);text-align:left;background-color:#0003;border-radius:6px;width:100%;max-width:450px;margin-top:1rem;padding:.75rem;font-size:.75rem}#end-rating-legend h5{color:var(--text-color);border-bottom:1px solid var(--border-color);margin:0 0 .5rem;padding-bottom:.25rem;font-size:.9rem;font-weight:600}#end-rating-legend ul{margin:0;padding:0;list-style:none}#end-rating-legend li{padding:.2rem 0;line-height:1.4}#end-rating-legend li strong{color:var(--secondary-color);font-weight:600}#screen-end .menu-buttons{text-align:center;flex-shrink:0;padding-top:1rem}#controls-container{z-index:200;background-color:var(--bg-color);border-top:1px solid var(--border-color);width:100%;padding-bottom:env(safe-area-inset-bottom);flex-shrink:0}#tab-buttons{display:flex}.tab-btn{background:var(--surface-color);color:var(--text-color);border:none;border-bottom:1px solid var(--border-color);border-top:1px solid var(--border-color);cursor:pointer;-webkit-tap-highlight-color:transparent;border-right:1px solid var(--bg-color);flex-grow:1;padding:.8rem;font-size:1rem;transition:background-color .2s,color .2s}#tab-buttons .tab-btn:last-child{border-right:none}.tab-btn.active{background:var(--bg-color);border-bottom-color:var(--bg-color);font-weight:700}.tab-panel{padding:1rem;display:none}.tab-panel.active{background:var(--bg-color);display:block}#actions-panel.active{flex-direction:column;gap:1rem;display:flex}#gem-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.toolbar-gem{cursor:grab;-webkit-tap-highlight-color:transparent;border:1px solid var(--border-color);border-radius:4px;justify-content:center;align-items:center;width:50px;height:50px;padding:2px;transition:transform .2s,opacity .2s;display:flex}.toolbar-gem.placed{opacity:.4;cursor:not-allowed}.toolbar-gem.dragging{opacity:.4}.toolbar-gem:not(.placed):hover{transform:scale(1.1)}.toolbar-gem-canvas{width:100%;height:100%}.mode-switch-wrapper{align-items:center;gap:1rem;display:flex}.mode-switch-wrapper>span{font-size:.9rem;font-weight:500}#mode-switch-container{border:1px solid var(--border-color);border-radius:6px;display:flex;overflow:hidden}.mode-btn{background-color:var(--surface-color);color:var(--text-color);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;flex-grow:1;padding:.5rem .8rem;font-size:.9rem;transition:all .2s}.mode-btn:not(:last-child){border-right:1px solid var(--border-color)}.mode-btn:hover:not(.active){background-color:var(--bg-color)}.mode-btn.active{background-color:var(--primary-color);color:#fff;font-weight:700}#action-buttons{gap:1rem;display:flex}#action-buttons button{border:1px solid var(--primary-color);background-color:var(--primary-color);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:5px;flex-grow:1;padding:.8rem;font-size:1rem;transition:all .2s}#action-buttons button#give-up-btn{background-color:var(--invalid-color);border-color:var(--invalid-color)}#action-buttons button:hover{background-color:var(--primary-hover)}#action-buttons button#give-up-btn:hover{background-color:#c0392b}#action-buttons button:disabled{color:#bdc3c7;cursor:not-allowed;background-color:#7f8c8d;border-color:#95a5a6}.preview-toggle-wrapper{-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;gap:1rem;display:flex}.preview-toggle-wrapper label{cursor:pointer;color:var(--text-color);font-size:.9rem}.preview-toggle-wrapper input[type=checkbox]{appearance:none;background-color:var(--surface-color);border:1px solid var(--border-color);cursor:pointer;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background-color .2s;position:relative}.preview-toggle-wrapper input[type=checkbox]:after{content:"";background-color:var(--text-color);border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:1px;left:1px;box-shadow:0 1px 2px #0003}.preview-toggle-wrapper input[type=checkbox]:checked{background-color:var(--primary-color);border-color:var(--primary-hover)}.preview-toggle-wrapper input[type=checkbox]:checked:after{transform:translate(20px)}#log-list{border:1px solid var(--border-color);background:var(--surface-color);border-radius:5px;height:200px;padding:.5rem;list-style-type:none;overflow-y:auto}#log-list li{border-bottom:1px solid var(--border-color);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:3px;justify-content:space-between;align-items:center;padding:.5rem;font-size:.9rem;transition:background-color .2s;display:flex}#log-list li:last-child{border-bottom:none}#log-list li.selected{background-color:var(--primary-hover);color:var(--text-color)}.log-entry-result{align-items:center;gap:.5rem;display:flex}.log-color-name{opacity:.9;font-size:.9em}.log-color-box{border:1px solid var(--border-color);flex-shrink:0;width:20px;height:20px}#rules-panel h4{border-bottom:1px solid var(--border-color);margin-top:1rem;margin-bottom:.5rem;padding-bottom:.25rem}#rules-panel h4:first-child{margin-top:0}#rules-panel ul{margin-bottom:1rem;padding-left:1.5rem;line-height:1.6}#rules-panel p{line-height:1.6}#rules-panel strong{color:var(--primary-color)}.color-mix-container{align-items:flex-start;gap:1.5rem;margin-top:.5rem;display:flex;overflow-x:auto}.color-mix-column{flex-direction:column;flex:1;gap:.4rem;display:flex}.color-mix-entry{align-items:center;gap:.3rem;font-size:.75rem;display:flex}.color-mix-box{border:1px solid var(--border-color);flex-shrink:0;width:15px;height:15px}#custom-shape-designer-modal{z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000b3;padding:1rem}.designer-content{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:500px;padding:2rem;animation:.3s ease-out fadeInModal;display:flex;box-shadow:0 8px 30px #00000080}@keyframes fadeInModal{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.designer-content h3{color:var(--primary-color);margin:0;font-size:1.5rem}.designer-content p{text-align:center;color:#fffc;max-width:90%;margin:-1rem 0 0;font-size:.95rem;line-height:1.5}.designer-grid-container{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;grid-template-rows:repeat(4,60px);grid-template-columns:repeat(4,60px);gap:5px;padding:10px;display:grid}.designer-cell{background-color:var(--surface-color);cursor:pointer;border:1px solid var(--border-color);border-radius:4px;width:100%;height:100%;padding:2px;transition:background-color .2s}.designer-cell:hover{background-color:var(--primary-hover)}.designer-cell canvas{pointer-events:none;width:100%;height:100%}#designer-preview-wrapper{flex-direction:column;align-items:center;gap:.5rem;display:flex}#designer-preview-wrapper h4{color:var(--text-color);border:none;margin:0;font-size:.9rem;font-weight:400}#designer-preview-canvas{background:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;width:80px;height:80px}#custom-shape-designer-modal .menu-buttons{flex-direction:row;align-items:center;gap:1rem;margin-top:1rem;display:flex}#custom-shape-designer-modal .menu-buttons button{justify-content:center;align-items:center;height:52px;margin:0;padding:0 2rem;display:inline-flex}@keyframes flash-bg{0%{background-color:var(--surface-color)}50%{background-color:var(--primary-hover)}to{background-color:var(--surface-color)}}#log-list.flash{animation:.6s ease-in-out flash-bg}@media (width<=420px){.title{margin-bottom:1.5rem;font-size:2.5rem}#screen-custom-creator .selector-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem}#intro-rules{padding:.8rem}#intro-rules h4{margin-top:.5rem}.color-mix-container{gap:.5rem}.color-mix-column{gap:.4rem}.designer-grid-container{grid-template-rows:repeat(4,50px);grid-template-columns:repeat(4,50px)}.designer-content{gap:1rem;padding:1.5rem 1rem}#custom-shape-designer-modal .menu-buttons{flex-direction:column;width:100%}#custom-shape-designer-modal .menu-buttons button{width:100%}}#rotate-board-btn{background-color:var(--primary-color);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:10;border:none;border-radius:50%;width:36px;height:36px;padding:0;font-size:1.3rem;line-height:1;transition:background-color .2s,transform .2s;display:none;position:absolute;bottom:.5rem;right:.5rem;box-shadow:0 2px 6px #0000004d}#rotate-board-btn:hover{background-color:var(--primary-hover);transform:scale(1.1)}#sidebar-rating-info{display:none}#game-board-wrapper.board-rotated{aspect-ratio:12/10}.panel-heading,#log-empty-msg{display:none}@media (orientation:landscape){#app{max-width:none}#rotate-board-btn{justify-content:center;align-items:center;display:flex}#screen-game{grid-template:"rules board log"1fr"rules actions log"/430px 1fr 300px;padding:0;display:grid}#game-container{grid-area:board;min-height:0;padding:.5rem;position:relative;overflow:hidden}#game-board-wrapper{max-width:450px}#game-board-wrapper.board-rotated{aspect-ratio:12/10;max-width:540px}#controls-container{display:contents}#tab-buttons{display:none!important}#tab-panels{display:contents}.panel-heading{color:var(--primary-color);border-bottom:1px solid var(--border-color);margin:0 0 .75rem;padding-bottom:.5rem;font-size:1.1rem;font-weight:600;display:block}#log-empty-msg{color:#ffffff80;text-align:center;padding:2rem 0;font-size:.85rem;font-style:italic;display:block}#rules-panel{background:var(--bg-color);border-right:1px solid var(--border-color);grid-area:rules;height:100%;padding:1rem 1.25rem;overflow-y:auto;display:block!important}#actions-panel{background:var(--bg-color);border-top:1px solid var(--border-color);flex-flow:wrap;grid-area:actions;align-items:center;gap:.75rem;padding:.6rem 1rem;display:flex!important}#actions-panel .mode-switch-wrapper{flex-shrink:0}#actions-panel #gem-toolbar-wrapper{flex:1;min-width:0}#actions-panel #gem-toolbar-wrapper>span{display:none}#actions-panel .preview-toggle-wrapper,#actions-panel #action-buttons{flex-shrink:0}#log-panel{background:var(--bg-color);border-left:1px solid var(--border-color);flex-direction:column;grid-area:log;height:100%;padding:1rem 1.25rem;overflow-y:auto;display:flex!important}#log-panel #log-list{flex:1;height:auto;max-height:none}#sidebar-rating-info{color:#ffffffb3;border:1px solid var(--border-color);background-color:#0003;border-radius:6px;margin-bottom:1rem;padding:.6rem .75rem;font-size:.75rem;display:block!important}#sidebar-rating-info h5{color:var(--text-color);border-bottom:1px solid var(--border-color);margin:0 0 .4rem;padding-bottom:.2rem;font-size:.85rem;font-weight:600}#sidebar-rating-info ul{margin:0;padding:0;list-style:none}#sidebar-rating-info li{padding:.15rem 0;line-height:1.3}#sidebar-rating-info li strong{color:var(--secondary-color);font-weight:600}#end-main-row{flex-direction:row;align-items:flex-start;gap:1.5rem;max-width:900px}#end-main-row #end-solution-wrapper{flex:1;min-width:0}#end-main-row #end-rating-legend{flex:0 0 280px;margin-top:0}#screen-main .screen-content{max-width:900px}#intro-rules{flex-direction:row;align-items:flex-start;gap:1.5rem;max-width:900px;display:flex}#intro-rules>.rules-details{border:none;flex:1;min-width:0}#intro-rules>.rules-details>.details-content{display:block!important}#intro-rules>.rules-details>.rules-summary:after{content:none}#intro-rules>.rules-details>.rules-summary{cursor:default;pointer-events:none;border-bottom:1px solid var(--border-color);margin-bottom:.5rem;padding-bottom:.5rem}}
