.admin{--paper:var(--color-paper);--paper-2:var(--color-paper-2);--cream:var(--color-cream);--wood:var(--color-wood);--wood-deep:var(--color-wood-deep);--ink:var(--color-ink);--ink-soft:var(--color-ink-soft);--jade:var(--color-jade);--gold:var(--color-gold);--rose:var(--color-rose);--line:#8a5e382e;--shadow:0 14px 40px -20px #52361c66;background:var(--paper);min-height:100vh;color:var(--ink);display:flex}.admin .side{background:var(--ink);color:#e7d9c0;flex-direction:column;flex:none;width:230px;padding:22px 16px;display:flex}.admin .side .logo{border-bottom:1px solid #c49a5233;align-items:center;gap:11px;margin-bottom:16px;padding:6px 8px 20px;text-decoration:none;display:flex}.admin .side .logo .mark{background:var(--gold);width:38px;height:38px;color:var(--ink);font-family:var(--font-serif);border-radius:50%;place-items:center;font-size:19px;font-weight:900;display:grid}.admin .side .logo b{font-family:var(--font-serif);color:#fbf6ec;font-size:15px;line-height:1.2;display:block}.admin .side .logo span{letter-spacing:2px;color:var(--gold);text-transform:uppercase;font-size:9px}.admin .nav-item{cursor:pointer;color:#d9c8ae;border-radius:11px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 14px;font-size:14.5px;text-decoration:none;transition:all .2s;display:flex}.admin .nav-item:hover{background:#ffffff0f}.admin .nav-item.active{background:var(--wood-deep);color:#fff}.admin .nav-item .ic{font-size:18px}.admin .side .foot{color:#d9c8ae80;border-top:1px solid #c49a5233;margin-top:auto;padding:12px 8px;font-size:11px}.admin .side .signout{color:#d9c8ae;cursor:pointer;background:0 0;border:1px solid #c49a524d;border-radius:9px;width:100%;margin-bottom:10px;padding:9px 12px;font-family:inherit;font-size:12.5px;transition:all .2s}.admin .side .signout:hover{color:#fff;border-color:var(--rose);background:#b8536a2e}.admin .main{flex:1;max-height:100vh;padding:28px 34px;overflow-y:auto}.admin .topbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:26px;display:flex}.admin .topbar h1{font-family:var(--font-serif);color:var(--ink);font-size:26px;font-weight:700}.admin .topbar .sub{color:var(--ink-soft);margin-top:3px;font-size:13px}.admin .user-badge{color:var(--wood-deep);background:#c49a5229;border-radius:999px;padding:6px 13px;font-size:11px;font-weight:600}.admin .grid-4{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px;display:grid}@media (max-width:900px){.admin .grid-4{grid-template-columns:repeat(2,1fr)}}.admin .stat{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:20px}.admin .stat .lbl{color:var(--ink-soft);margin-bottom:8px;font-size:12.5px}.admin .stat .val{font-family:var(--font-display);color:var(--wood-deep);font-size:30px;font-weight:600;line-height:1}.admin .stat .val small{color:var(--ink-soft);font-size:15px}.admin .stat .delta{margin-top:7px;font-size:11.5px}.admin .up{color:var(--jade)}.admin .down{color:var(--rose)}.admin .card{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;margin-bottom:22px;padding:24px}.admin .card h2{font-family:var(--font-serif);align-items:center;gap:9px;margin-bottom:16px;font-size:18px;display:flex}.admin .card h2 .tag{color:var(--jade);background:#6e8f6b26;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:400}.admin table{border-collapse:collapse;width:100%;font-size:13.5px}.admin th{text-align:left;color:var(--ink-soft);border-bottom:2px solid var(--line);text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;font-size:12px;font-weight:500}.admin td{border-bottom:1px solid var(--line);padding:12px}.admin tr:last-child td{border-bottom:none}.admin tr:hover td{background:#b68a5e0d}.admin .pill{border-radius:999px;padding:3px 11px;font-size:11px;font-weight:500;display:inline-block}.admin .pill.ok{color:#43663f;background:#6e8f6b2e}.admin .pill.warn{color:#8a6a25;background:#c49a5233}.admin .pill.due{color:#a13a52;background:#b8536a29}.admin .btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:7px;padding:10px 18px;font-family:inherit;font-size:13.5px;font-weight:600;transition:all .2s;display:inline-flex}.admin .btn-primary{background:var(--wood-deep);color:#fff}.admin .btn-primary:hover{background:var(--ink);transform:translateY(-1px)}.admin .btn-ghost{border:1.5px solid var(--wood);color:var(--wood-deep);background:0 0}.admin .btn-ghost:hover{background:var(--wood-deep);color:#fff}.admin .btn-sm{border-radius:8px;padding:6px 13px;font-size:12px}.admin .split{grid-template-columns:1fr 1fr;gap:22px;display:grid}@media (max-width:900px){.admin .split{grid-template-columns:1fr}}.admin .input{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:9px;margin-bottom:12px;padding:11px 13px;font-family:inherit;font-size:14px}.admin .input:focus{border-color:var(--wood-deep);outline:none;box-shadow:0 0 0 3px #8a5e381f}.admin .field-lbl{color:var(--ink-soft);margin-bottom:5px;font-size:12.5px;display:block}.admin .mini-add{background:var(--cream);border:1px dashed var(--wood);border-radius:13px;margin-top:14px;padding:18px}.admin .row2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.admin .pos-wrap{grid-template-columns:1.5fr 1fr;gap:20px;display:grid}@media (max-width:900px){.admin .pos-wrap{grid-template-columns:1fr}}.admin .prod-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (max-width:600px){.admin .prod-grid{grid-template-columns:repeat(2,1fr)}}.admin .prod{background:var(--paper-2);border:1px solid var(--line);cursor:pointer;text-align:center;color:inherit;border-radius:13px;padding:15px;font-family:inherit;transition:all .2s}.admin .prod:hover:not(:disabled){border-color:var(--wood);box-shadow:var(--shadow);transform:translateY(-3px)}.admin .prod .emoji{font-size:30px}.admin .prod .nm{color:var(--ink);margin:7px 0 3px;font-size:13px;font-weight:500}.admin .prod .pr{font-family:var(--font-display);color:var(--wood-deep);font-size:18px;font-weight:600}.admin .prod .stk{color:var(--ink-soft);margin-top:3px;font-size:10.5px}.admin .prod.out,.admin .prod:disabled{opacity:.45;pointer-events:none;cursor:not-allowed}.admin .cart{background:var(--ink);color:#e7d9c0;border-radius:16px;padding:20px;position:sticky;top:0}.admin .cart h3{font-family:var(--font-serif);color:#fbf6ec;margin-bottom:14px;font-size:16px}.admin .cart-item{border-bottom:1px solid #c49a522e;justify-content:space-between;align-items:center;padding:9px 0;font-size:13px;display:flex}.admin .cart-item .x{cursor:pointer;color:var(--rose);margin-left:8px;padding:0 4px;font-size:16px;display:inline-block}.admin .cart-empty{color:#9a8a72;text-align:center;padding:24px 0;font-size:13px}.admin .cart-total{justify-content:space-between;margin:14px 0;font-size:15px;display:flex}.admin .cart-total b{font-family:var(--font-display);color:var(--gold);font-size:26px}.admin .cart .btn-primary{background:var(--gold);width:100%;color:var(--ink);justify-content:center}.admin .cart .btn-primary:hover:not(:disabled){background:#fff}.admin .cart .btn-primary:disabled{opacity:.6;cursor:not-allowed}.admin .qty{color:#c9b79c;margin-left:6px;font-size:11px}.admin .toast{background:var(--ink);color:#fff;box-shadow:var(--shadow);z-index:99;opacity:0;pointer-events:none;border-radius:12px;padding:13px 26px;font-size:14px;transition:all .35s;position:fixed;bottom:26px;left:50%;transform:translate(-50%)translateY(80px)}.admin .toast.show{opacity:1;transform:translate(-50%)translateY(0)}.admin .bars{align-items:flex-end;gap:14px;height:180px;padding:10px 0;display:flex}.admin .bar-col{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.admin .bar{background:linear-gradient(180deg, var(--wood), var(--wood-deep));border-radius:7px 7px 0 0;width:100%;max-width:46px;min-height:4px;transition:all .6s}.admin .bar-col span{color:var(--ink-soft);font-size:11px}.admin .bar-col b{color:var(--wood-deep);font-size:11px}.admin .bar-current{background:linear-gradient(180deg, var(--gold), var(--wood-deep))}.admin .menu-toggle{display:none}@media (max-width:760px){.admin .side{z-index:80;height:100%;transition:all .3s;position:fixed;left:-240px}.admin .side.open{left:0}.admin .menu-toggle{background:var(--wood-deep);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:8px 13px;font-size:18px;display:inline-flex}}.login-shell{background:radial-gradient(circle at 20% 20%, #c49a522e, transparent 50%), radial-gradient(circle at 80% 80%, #8a5e382e, transparent 50%), var(--color-paper);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--color-paper-2);border:1px solid #8a5e382e;border-radius:22px;width:100%;max-width:420px;padding:38px 32px;box-shadow:0 30px 60px -30px #52361c59}.login-card .brand-row{align-items:center;gap:12px;margin-bottom:22px;display:flex}.login-card .brand-mark{border:1.5px solid var(--color-wood-deep);width:44px;height:44px;color:var(--color-wood-deep);font-family:var(--font-serif);background:radial-gradient(circle at 35% 30%,#fbf6ec,#e7d6bc);border-radius:50%;place-items:center;font-size:21px;display:grid;box-shadow:inset 0 0 0 3px #fff9}.login-card .brand-row b{font-family:var(--font-serif);color:var(--color-ink);font-size:16px;font-weight:700;line-height:1.2}.login-card .brand-row span{letter-spacing:3px;color:var(--color-wood-deep);text-transform:uppercase;font-size:10px}.login-card h1{font-family:var(--font-serif);color:var(--color-ink);margin-bottom:6px;font-size:24px}.login-card .sub{color:var(--color-ink-soft);margin-bottom:22px;font-size:13.5px}.login-card label{color:var(--color-ink-soft);margin-bottom:5px;font-size:12.5px;display:block}.login-card input{width:100%;color:var(--color-ink);background:#fff;border:1px solid #8a5e382e;border-radius:10px;margin-bottom:14px;padding:12px 14px;font-family:inherit;font-size:14px}.login-card input:focus{border-color:var(--color-wood-deep);outline:none;box-shadow:0 0 0 3px #8a5e381f}.login-card button{background:var(--color-wood-deep);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:6px;padding:13px;font-family:inherit;font-size:14.5px;font-weight:600;transition:all .2s}.login-card button:hover{background:var(--color-ink)}.login-card button:disabled{opacity:.6;cursor:not-allowed}.login-card .err{color:#a13a52;background:#b8536a1a;border:1px solid #b8536a33;border-radius:9px;margin-bottom:14px;padding:10px 12px;font-size:13px}.login-card .back{text-align:center;color:var(--color-ink-soft);margin-top:16px;font-size:12.5px;text-decoration:none;display:block}.login-card .back:hover{color:var(--color-wood-deep)}.admin .modal{border:1px solid var(--line);background:var(--paper-2);color:var(--ink);border-radius:14px;width:min(520px,92vw);max-height:90vh;padding:0;box-shadow:0 30px 80px -20px #34291e80}.admin .modal::backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#34291e73}.admin .modal .modal-body{padding:22px 22px 18px}.admin .modal h3{font-family:var(--font-serif);color:var(--ink);margin:0 0 4px;font-size:20px}.admin .modal select.input{appearance:none;cursor:pointer;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%238A5E38' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") right 13px center no-repeat;padding-right:36px}.admin .modal-actions{border-top:1px dashed var(--line);justify-content:flex-end;gap:8px;margin-top:18px;padding-top:14px;display:flex}.invoice-shell{max-width:760px;margin:0 auto;padding:20px 16px 60px}.invoice-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;margin-bottom:18px;display:flex}.invoice{color:#34291e;font-family:var(--font-sans);background:#fff;border:1px solid #8a5e382e;border-radius:16px;padding:36px 38px;font-size:14px;box-shadow:0 14px 40px -20px #52361c4d}.inv-head{border-bottom:2px solid #8a5e38;flex-wrap:wrap;justify-content:space-between;gap:18px;margin-bottom:22px;padding-bottom:18px;display:flex}.inv-brand-block{flex:auto;align-items:flex-start;gap:14px;min-width:0;display:flex}.inv-logo{object-fit:contain;flex:none;width:72px;height:72px}.inv-brand-info{color:#5c4b39;min-width:0;font-size:11.5px;line-height:1.55}.inv-brand-en{font-family:var(--font-serif);color:#34291e;letter-spacing:.5px;white-space:nowrap;margin-bottom:4px;font-size:15px;font-weight:700}.inv-brand{color:#34291e;letter-spacing:1px;white-space:nowrap;flex:none;font-size:20px;font-weight:700}.inv-brand-sub{color:#5c4b39;margin-top:2px;font-size:12px}.inv-meta{text-align:right;flex:none;min-width:150px;font-size:12.5px;line-height:1.7}.inv-title{font-family:var(--font-display);letter-spacing:4px;color:#c49a52;white-space:nowrap;margin-bottom:6px;font-size:26px}@media (max-width:560px){.invoice{padding:22px 18px}.inv-head{flex-direction:column;align-items:stretch;gap:12px}.inv-meta{text-align:left;min-width:0}.inv-title{font-size:24px}.inv-brand-en{white-space:normal}}.inv-meta-lbl{text-transform:uppercase;letter-spacing:1px;color:#8a5e38;font-size:11px;font-weight:600}.inv-billto{background:#fbf6ec;border-left:3px solid #c49a52;border-radius:0 8px 8px 0;margin-bottom:22px;padding:12px 16px;font-size:13px;line-height:1.7}.inv-billto-name{margin:2px 0 4px;font-size:17px;font-weight:700}.inv-table{border-collapse:collapse;width:100%;margin-bottom:22px}.inv-table th,.inv-table td{border-bottom:1px solid #8a5e382e;padding:11px 12px;font-size:13px}.inv-table thead th{color:#5c4b39;text-align:left;background:#f7f1e6;border-bottom:2px solid #8a5e38;font-weight:600}.inv-table tfoot td{border-bottom:none;padding-top:14px;font-size:15px}.inv-foot{border-top:1px dashed #8a5e384d;flex-wrap:wrap;align-items:center;gap:28px;padding:14px 0;font-size:13px;line-height:1.6;display:flex}.inv-foot>div{min-width:120px}.inv-status{margin-left:auto}.inv-paid{font-family:var(--font-display);color:#6e8f6b;letter-spacing:2px;border:2px solid #6e8f6b;border-radius:6px;padding:4px 14px;font-size:22px;font-weight:700;display:inline-block;transform:rotate(-4deg)}.inv-thanks{text-align:center;font-family:var(--font-serif);color:#5c4b39;letter-spacing:1px;border-top:1px solid #8a5e382e;margin-top:24px;padding-top:16px;font-size:13px}@media print{body{background:#fff!important}.no-print,.admin .side,.admin .topbar{display:none!important}.invoice-shell{max-width:none;padding:0}.invoice{box-shadow:none;border:none;border-radius:0;padding:24px 28px}}.admin .week-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.admin .week-col{background:var(--paper-2,#fdf8ef);border:1px solid #0000000f;border-radius:12px;flex-direction:column;gap:8px;min-height:140px;padding:10px 8px;display:flex}.admin .week-col-head{border-bottom:1px solid #00000014;justify-content:space-between;align-items:baseline;padding-bottom:6px;display:flex}.admin .week-col-head b{font-family:var(--font-serif,serif);color:var(--ink,#2a1c0f);font-size:14px}.admin .week-col-head span{color:var(--ink-soft,#7a6a55);font-size:11px}.admin .week-empty{text-align:center;color:var(--ink-soft,#7a6a55);padding:16px 0;font-size:13px}.admin .week-slot{background:#fff;border:1px solid #8a5e382e;border-radius:10px;padding:8px 10px;font-size:12px;line-height:1.4}.admin .week-slot-time{color:var(--wood-deep,#6b4318);justify-content:space-between;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.admin .week-slot-dur{background:var(--cream,#f3e9d2);color:var(--wood-deep,#6b4318);border-radius:999px;padding:1px 6px;font-size:10px;font-weight:600}.admin .week-slot-name{color:var(--ink,#2a1c0f);margin-top:4px;font-size:13px;font-weight:600}.admin .week-slot-sub{color:var(--ink-soft,#7a6a55);font-size:11px}@media (max-width:900px){.admin .week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:520px){.admin .week-grid{grid-template-columns:1fr}}.admin .week-col-today{background:#fff9ea;border-color:#c49a5273;box-shadow:0 0 0 2px #c49a5226}.admin .week-col-date{color:var(--ink-soft);margin-left:2px;font-size:11px;font-weight:400}.admin .week-slot-clickable{text-align:left;cursor:pointer;width:100%;font-family:inherit;transition:all .15s;display:block}.admin .week-slot-clickable:hover:not(:disabled){border-color:var(--wood);transform:translateY(-1px);box-shadow:0 6px 14px -10px #52361c59}.admin .week-slot-clickable:disabled{opacity:.6;cursor:progress}.admin .week-slot-att{justify-content:flex-end;margin-top:6px;display:flex}.admin .att-pill{border:1px solid #0000;border-radius:999px;padding:2px 8px;font-size:10.5px;font-weight:600}.admin .att-pending{color:var(--ink-soft);background:#0000000a;border-color:#00000014}.admin .att-present{color:#2f7d4f;background:#e8f5ec;border-color:#b6dcc1}.admin .att-makeup{color:#7a5a13;background:#fff4dd;border-color:#ebcf91}.admin .att-absent{color:#a13a2b;background:#fde7e3;border-color:#efb7ac}.admin .att-teacher-leave{color:#234a6e;background:#e3eef8;border-color:#b4cbe0}.admin .week-slot.att-present{background:#f3faf5;border-color:#b6dcc1}.admin .week-slot.att-makeup{background:#fffaf0;border-color:#ebcf91}.admin .week-slot.att-absent{background:#fdf4f1;border-color:#efb7ac}.admin .week-slot.att-teacher-leave{background:#f1f6fb;border-color:#b4cbe0}.admin .week-slot.week-slot-makeup{background:repeating-linear-gradient(135deg,#fffaf0 0 14px,#fff4dd 14px 16px);border:2px dashed #c98c2b}.admin .att-makeup-card{color:#7a5a13;background:#fff4dd;border-color:#c98c2b}.admin .week-col-holiday{background:repeating-linear-gradient(135deg,#f1f6fb 0 14px,#e3eef8 14px 16px);border-color:#b4cbe0}.admin .holiday-banner{text-align:center;color:#234a6e;background:#e3eef8;border:2px dashed #3d6a96;border-radius:10px;padding:14px 10px}.admin .holiday-banner-title{font-family:var(--font-serif,serif);font-size:14px;font-weight:700}.admin .holiday-banner-note{margin-top:4px;font-size:12px;font-style:italic}.admin .holiday-banner-sub{color:#234a6eb3;margin-top:6px;font-size:11px}.admin .site-editor-tabs{border-bottom:1px solid var(--border,#e5d9c1);flex-wrap:wrap;gap:4px;margin-bottom:4px;display:flex}.admin .site-tab{appearance:none;color:var(--ink-soft,#7a6a52);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;margin-bottom:-1px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.admin .site-tab:hover{color:var(--ink,#34291e);background:#c49a5214}.admin .site-tab.active{color:var(--ink,#34291e);border-bottom-color:var(--gold,#c49a52);background:#c49a521a;font-weight:600}.admin .site-item-card{border:1px solid var(--border,#e5d9c1);background:#fdfaf3;border-radius:10px;margin-bottom:10px;padding:12px}
