*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #3B82F6;--blue-dark: #2563EB;--bg: #F8FAFC;--surface: #FFFFFF;--border: #E2E8F0;--text: #1E293B;--text-soft: #64748B;--radius: 16px;--shadow: 0 2px 8px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.14);font-size:16px}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;overscroll-behavior:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;touch-action:manipulation}.app{display:flex;flex-direction:column;height:100dvh;max-height:100dvh;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 1rem;height:52px;background:linear-gradient(135deg,#1d4ed8,#7c3aed);color:#fff;flex-shrink:0;box-shadow:0 2px 12px #1d4ed873}.app-title{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;letter-spacing:.5px}.logo-img{width:32px;height:32px;border-radius:8px;object-fit:contain;flex-shrink:0}.app-footer{text-align:center;font-size:.65rem;color:var(--text-soft);padding:2px 0 3px;flex-shrink:0;background:var(--bg);letter-spacing:.3px;opacity:.7}.app-controls{display:flex;gap:.5rem;align-items:center}.size-btn,.admin-btn,.share-btn{background:#fff3;border-radius:10px;padding:.35rem .65rem;font-size:1.1rem;color:#fff;transition:background .15s}.size-btn:hover,.admin-btn:hover,.share-btn:hover{background:#ffffff59}.size-btn.active{background:#fff6}.share-btn{padding:.35rem .5rem;display:flex;align-items:center;justify-content:center}.share-btn svg{width:19px;height:19px;display:block}.share-btn:active{transform:scale(.9)}.share-toast{position:fixed;bottom:1.8rem;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:.5rem 1.2rem;border-radius:999px;font-size:.88rem;font-weight:600;pointer-events:none;z-index:999;animation:toast-in .18s ease,toast-out .25s ease 1.8s forwards;white-space:nowrap;box-shadow:0 4px 16px #00000038}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toast-out{0%{opacity:1}to{opacity:0}}.sentence-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#dbeafe;border-bottom:2px solid #BFDBFE;min-height:68px;flex-shrink:0;overflow-x:auto}.sentence-bar__words{display:flex;gap:.4rem;align-items:center;flex:1;overflow-x:auto;min-width:0;padding-bottom:2px}.sentence-bar__placeholder{color:var(--text-soft);font-size:.9rem;white-space:nowrap}.sentence-chip{display:flex;flex-direction:column;align-items:center;gap:2px;background:#fff;border:2px solid #93C5FD;border-radius:12px;padding:.3rem .5rem;font-size:.75rem;font-weight:600;white-space:nowrap;min-width:56px;transition:transform .1s;flex-shrink:0}.sentence-chip:active{transform:scale(.93)}.sentence-chip__img{width:36px;height:36px;object-fit:contain}.sentence-chip__emoji{font-size:1.4rem;line-height:1}.sentence-bar__actions{display:flex;gap:.4rem;flex-shrink:0}.btn-speak,.btn-clear{width:48px;height:48px;border-radius:12px;font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:transform .1s,opacity .15s}.btn-speak{background:#22c55e;color:#fff;box-shadow:0 2px 8px #22c55e59}.btn-speak:disabled{opacity:.4}.btn-speak:not(:disabled):active{transform:scale(.9)}.btn-clear{background:#ef4444;color:#fff;box-shadow:0 2px 8px #ef44444d}.btn-clear:disabled{opacity:.4}.btn-clear:not(:disabled):active{transform:scale(.9)}.category-nav{display:flex;gap:.35rem;padding:.4rem .75rem;overflow-x:auto;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);scrollbar-width:none}.category-nav::-webkit-scrollbar{display:none}.cat-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:.3rem .6rem;border-radius:10px;background:var(--bg);border:2px solid transparent;font-size:.7rem;font-weight:600;white-space:nowrap;min-width:52px;transition:background .12s,border-color .12s,transform .1s;flex-shrink:0;color:var(--text-soft)}.cat-btn span:first-child{font-size:1.2rem;line-height:1}.cat-btn:hover{background:#eff6ff}.cat-btn.active{background:var(--cat-color, var(--blue));border-color:var(--cat-color, var(--blue));color:#fff}.cat-btn:active{transform:scale(.93)}.app-main{flex:1;overflow-y:auto;overflow-x:hidden;padding:.6rem}.board{display:grid;gap:.6rem;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.board--large{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem}.board--loading{display:flex;align-items:center;justify-content:center;height:200px}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.word-card{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.3rem;background:#fff;border:3px solid var(--card-color, #4A90E2);border-radius:var(--radius);padding:.5rem .4rem;aspect-ratio:1;box-shadow:var(--shadow);transition:transform .1s,box-shadow .1s;overflow:hidden;position:relative}.word-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--card-color, #4A90E2);border-radius:12px 12px 0 0}.word-card:active{transform:scale(.9);box-shadow:0 1px 4px #0000001f}.word-card__image{flex:1;display:flex;align-items:center;justify-content:center;width:100%}.word-card__image img{max-width:100%;max-height:70px;object-fit:contain}.word-card.large .word-card__image img{max-height:90px}.word-card__emoji{font-size:2.4rem;line-height:1}.word-card.large .word-card__emoji{font-size:3rem}.word-card__label{font-size:.72rem;font-weight:700;text-align:center;line-height:1.2;color:var(--text);word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.word-card.large .word-card__label{font-size:.85rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#fff;border-radius:24px;padding:2rem 1.5rem;width:100%;max-width:320px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:1rem}.modal h2{font-size:1.25rem;font-weight:700}.modal p{color:var(--text-soft);font-size:.9rem}.pin-display{font-size:2rem;letter-spacing:.5rem;color:var(--blue);font-weight:700;min-height:2.5rem}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;width:100%}.pin-btn{height:56px;border-radius:14px;background:var(--bg);font-size:1.4rem;font-weight:700;color:var(--text);border:2px solid var(--border);transition:background .1s,transform .1s}.pin-btn:not([disabled]):active{transform:scale(.92);background:#dbeafe}.pin-btn--empty{visibility:hidden}.pin-btn:disabled{opacity:0}.error-msg{color:#ef4444;font-size:.85rem;font-weight:600}.modal-actions{display:flex;gap:.75rem;width:100%;margin-top:.5rem}.btn-primary{flex:1;background:var(--blue);color:#fff;border-radius:12px;padding:.65rem 1rem;font-weight:700;font-size:1rem;transition:background .15s,transform .1s}.btn-primary:hover{background:var(--blue-dark)}.btn-primary:active{transform:scale(.96)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-secondary{flex:1;background:var(--bg);color:var(--text-soft);border:2px solid var(--border);border-radius:12px;padding:.65rem 1rem;font-weight:600;transition:background .15s}.btn-secondary:hover{background:#f1f5f9}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;display:flex;align-items:flex-start;justify-content:flex-end}.admin-panel{width:100%;max-width:480px;height:100%;background:#fff;display:flex;flex-direction:column;overflow:hidden;box-shadow:-4px 0 24px #0000002e}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--blue);color:#fff;flex-shrink:0}.admin-header h2{font-size:1.1rem}.btn-close{background:#fff3;color:#fff;width:36px;height:36px;border-radius:10px;font-size:1rem;display:flex;align-items:center;justify-content:center}.btn-close:hover{background:#ffffff59}.admin-flash{background:#dcfce7;color:#166534;padding:.5rem 1rem;font-weight:600;font-size:.85rem;text-align:center}.admin-tabs{display:flex;border-bottom:2px solid var(--border);flex-shrink:0}.tab{flex:1;padding:.75rem;font-weight:600;font-size:.9rem;color:var(--text-soft);border-bottom:3px solid transparent;transition:color .15s,border-color .15s;margin-bottom:-2px}.tab.active{color:var(--blue);border-bottom-color:var(--blue)}.admin-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1.25rem}.admin-form{background:var(--bg);border-radius:14px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.admin-form h3{font-size:.95rem;font-weight:700;color:var(--text-soft)}.form-row{display:flex;gap:.5rem;flex-wrap:wrap}.input{flex:1;min-width:100px;padding:.55rem .75rem;border:2px solid var(--border);border-radius:10px;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .15s}.input:focus{border-color:var(--blue)}input[type=color]{width:44px;height:40px;border:2px solid var(--border);border-radius:10px;padding:2px;cursor:pointer;flex-shrink:0}.preview-img{display:flex;justify-content:center}.preview-img img{width:80px;height:80px;object-fit:contain}.word-list{display:flex;flex-direction:column;gap:.5rem}.word-list h3{font-size:.9rem;font-weight:700;color:var(--text-soft);margin-bottom:.25rem}.word-table{display:flex;flex-direction:column;gap:.35rem;max-height:340px;overflow-y:auto}.word-row{display:flex;align-items:center;gap:.6rem;background:var(--bg);border-radius:10px;padding:.4rem .6rem}.word-row.inactive{opacity:.45}.word-row__img{width:36px;height:36px;object-fit:contain;flex-shrink:0}.word-row__text{flex:1;font-size:.88rem;font-weight:600}.word-row__cat{font-size:.75rem;color:var(--text-soft);white-space:nowrap}.word-row__actions{display:flex;gap:.3rem;flex-shrink:0}.btn-toggle,.btn-delete{width:32px;height:32px;border-radius:8px;font-size:.9rem;display:flex;align-items:center;justify-content:center;background:var(--border);transition:background .12s,transform .1s}.btn-toggle.active{background:#dcfce7}.btn-delete{background:#fee2e2}.btn-toggle:active,.btn-delete:active{transform:scale(.9)}.cat-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.admin-loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.1rem;color:var(--text-soft)}.arasaac-picker{border:2px solid var(--border);border-radius:12px;padding:.75rem;background:#fff}.arasaac-picker__search{display:flex;gap:.5rem;margin-bottom:.75rem}.arasaac-picker__empty{text-align:center;color:var(--text-soft);font-size:.85rem;padding:.5rem}.arasaac-picker__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.arasaac-thumb{border:2px solid var(--border);border-radius:10px;padding:.25rem;background:var(--bg);aspect-ratio:1;display:flex;align-items:center;justify-content:center;transition:border-color .12s,transform .1s}.arasaac-thumb:hover{border-color:var(--blue)}.arasaac-thumb:active{transform:scale(.92)}.arasaac-thumb img{width:100%;height:100%;object-fit:contain}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}@media(max-width:400px){.board{grid-template-columns:repeat(auto-fill,minmax(85px,1fr))}.board--large{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.word-card__emoji{font-size:2rem}}@media(min-width:768px){.board{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.board--large{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}
