*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Plus Jakarta Sans,Inter,system-ui,-apple-system,sans-serif;background:#f0f2f5;color:#1e293b;padding:0;min-height:100vh;-webkit-font-smoothing:antialiased}.app{width:100%;margin:0;display:grid;gap:0;min-height:100vh;grid-template-rows:auto 1fr;min-width:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}header{background:linear-gradient(135deg,#0f1b2d,#1e3a5f,#2d6a9f);color:#fff;padding:16px 32px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:0 4px 24px #0000001f;position:sticky;top:0;z-index:100;min-width:0}header h1{font-size:22px;font-weight:800;letter-spacing:-.5px;display:flex;align-items:center;gap:10px;white-space:nowrap}header h1 i{color:#fbbf24;font-size:24px}header .header-left{flex:1;display:flex;align-items:center;gap:16px;min-width:0}header .header-meta{display:flex;align-items:center;gap:12px;font-size:13px;opacity:.85}header .header-meta .menu-badge{background:#fbbf2426;border:1px solid rgba(251,191,36,.25);padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}header .header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.code-badge{background:#ffffff1f;padding:6px 16px;border-radius:100px;font-size:16px;font-weight:800;letter-spacing:2px;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none;border:1px solid rgba(255,255,255,.1);white-space:nowrap}.code-badge:hover{background:#fff3}.code-badge i{font-size:12px;margin-right:6px;letter-spacing:0;opacity:.7}.header-btn{width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-size:15px;border:none;background:#ffffff14;color:#fff;flex-shrink:0}.header-btn:hover{background:#ffffff2e;transform:translateY(-1px)}.header-btn.whatsapp{background:#25d3661f;color:#25d366}.header-btn.whatsapp:hover{background:#25d366;color:#fff}.header-btn.github{color:#fff}.header-btn.github:hover{background:#ffffff2e}.leave-btn{background:#ef444426;border:1px solid rgba(239,68,68,.2);color:#fca5a5;padding:7px 14px;border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit;transition:all .15s;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}.leave-btn:hover{background:#ef444440}.admin-link{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px;border-radius:8px;transition:.15s;font-family:inherit;display:flex;align-items:center;gap:6px;white-space:nowrap}.admin-link:hover{color:#1e3a5f;background:#f1f5f9}.layout{display:grid;grid-template-columns:1fr 380px;gap:24px;padding:24px 32px;align-items:start;min-width:0}.layout>*{min-width:0}.persons-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:#fff;border-radius:0;padding:10px 32px;border-bottom:1px solid #e2e8f0;margin:0;min-width:0}.person-chip{padding:7px 16px;border-radius:100px;border:1.5px solid #e2e8f0;background:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;color:#475569;font-family:inherit;display:inline-flex;align-items:center;gap:8px;box-shadow:0 1px 2px #00000005}.person-chip:hover{border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f61a}.person-chip.active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 12px #2563eb40}.person-chip .p-count{background:#0000001a;font-size:10px;padding:1px 7px;border-radius:100px;font-weight:700}.person-chip.active .p-count{background:#fff3}.person-chip .p-del{margin-left:2px;font-size:11px;opacity:.4;cursor:pointer;transition:opacity .15s}.person-chip .p-del:hover{opacity:1}.add-person-btn{padding:7px 16px;border-radius:100px;border:1.5px dashed #94a3b8;background:transparent;font-size:12px;font-weight:600;cursor:pointer;color:#64748b;font-family:inherit;transition:all .12s}.add-person-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#3b82f60a}.cats{display:flex;gap:5px;margin-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;min-width:0;max-width:100%}.cats::-webkit-scrollbar{display:none}.cat-btn{padding:7px 14px;border:1.5px solid #e2e8f0;border-radius:100px;background:#fff;font-size:12px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0;box-shadow:0 1px 2px #00000005}.cat-btn i{font-size:12px}.cat-btn:hover{border-color:#0f4c3a;color:#0f4c3a;transform:translateY(-1px);box-shadow:0 2px 8px #05966914}.cat-btn.active{background:linear-gradient(135deg,#0f4c3a,#1a7a5e);color:#fff;border-color:transparent;box-shadow:0 2px 12px #05966940}.search-bar{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:8px 14px;margin-bottom:14px;transition:border-color .2s,box-shadow .2s}.search-bar:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-bar i{color:#94a3b8;font-size:15px}.search-bar input{flex:1;border:none;outline:none;background:transparent;font-size:14px;font-family:inherit;color:#1e293b;min-width:0}.search-bar input::placeholder{color:#94a3b8}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;min-width:0}.menu-grid>*{min-width:0}.menu-grid .menu-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:3px;box-shadow:0 1px 3px #0000000a;min-width:0;word-wrap:break-word;overflow-wrap:break-word}.menu-grid .menu-card:hover{border-color:#3b82f6;box-shadow:0 4px 16px #3b82f61f;transform:translateY(-2px)}.menu-grid .menu-card:active{transform:translateY(0);box-shadow:0 1px 4px #3b82f614}.menu-grid .menu-card.selected{border-color:#059669;background:#f0fdf4;box-shadow:0 0 0 2px #86efac}.menu-card .item-code{font-size:10px;color:#94a3b8;font-weight:700;background:#f1f5f9;padding:2px 8px;border-radius:5px;display:inline-block;width:fit-content}.menu-card .item-name{font-size:14px;font-weight:600;color:#1e293b;line-height:1.35}.menu-card .item-price{font-size:15px;font-weight:800;color:#059669;margin-top:6px;padding-top:6px;border-top:1px solid #f1f5f9}.menu-card .item-ingredients{font-size:11px;color:#94a3b8;line-height:1.4}.menu-card .item-qty-badge{position:absolute;top:-6px;right:-6px;background:#059669;color:#fff;font-size:11px;font-weight:700;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0596694d}.menu-card .qty-controls{display:flex;align-items:center;gap:8px;margin-top:8px}.menu-card .qty-controls button{width:28px;height:28px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .15s;color:#475569}.menu-card .qty-controls button:hover{background:#f1f5f9;border-color:#3b82f6;color:#3b82f6}.menu-card .code{font-size:10px;font-weight:700;color:#94a3b8;background:#f1f5f9;padding:2px 8px;border-radius:5px;width:fit-content}.menu-card .name{font-size:13px;font-weight:600;line-height:1.35;color:#1e293b}.menu-card .price{font-size:14px;font-weight:800;color:#059669;margin-top:auto;padding-top:6px;border-top:1px solid #f1f5f9}.menu-card .ingredients{font-size:11px;color:#94a3b8}.menu-card .added-badge{position:absolute;top:-5px;right:-5px;background:#059669;color:#fff;font-size:11px;font-weight:700;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0596694d}.section-title{font-size:13px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;padding:8px 0;border-bottom:2px solid #e2e8f0;margin:12px 0 8px}.order-panel{background:#fff;border-radius:20px;border:1px solid #e2e8f0;padding:20px;position:sticky;top:100px;max-height:calc(100vh - 120px);display:flex;flex-direction:column;box-shadow:0 4px 20px #0000000f;transition:box-shadow .2s}.order-panel:hover{box-shadow:0 8px 32px #00000014}.order-panel-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}.order-panel-header .op-avatar{width:36px;height:36px;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.order-panel-header h2{font-size:16px;font-weight:700;flex:1}.order-panel-header .op-count{background:#2563eb;color:#fff;font-size:11px;padding:2px 10px;border-radius:100px;font-weight:700}.order-panel .order-sub{font-size:12px;color:#94a3b8;margin-bottom:14px;margin-left:46px}.order-items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;min-height:100px;scrollbar-width:thin}.order-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#cbd5e1;gap:10px;padding:40px 0}.order-empty i{font-size:36px}.order-empty p{font-size:13px;font-weight:600}.order-item{background:#f8fafc;border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:10px;border:1px solid #e2e8f0;animation:slideIn .2s ease;transition:border-color .15s}.order-item:hover{border-color:#cbd5e1}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.order-item .oi-code{font-size:10px;font-weight:700;color:#94a3b8;min-width:24px}.order-item .oi-info{flex:1;min-width:0}.order-item .oi-name{font-size:12px;font-weight:600;color:#1e293b}.order-item .oi-qty{display:flex;align-items:center;gap:4px}.order-item .oi-qty button{width:24px;height:24px;border-radius:7px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .1s}.order-item .oi-qty button:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.order-item .oi-qty .qty-num{font-size:14px;font-weight:700;min-width:20px;text-align:center}.order-item .oi-remove{width:24px;height:24px;border-radius:7px;border:none;background:#fef2f2;color:#ef4444;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;transition:all .1s}.order-item .oi-remove:hover{background:#ef4444;color:#fff}.order-person-total{margin-top:12px;padding:10px 14px;background:#f0fdf4;border-radius:12px;display:flex;justify-content:space-between;font-size:14px;font-weight:700;color:#059669;border:1px solid #bbf7d0}.group-summary{margin-top:14px;padding-top:14px;border-top:2px solid #e2e8f0}.group-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px}.group-row .gr-name{font-weight:600;color:#475569}.group-row .gr-total{font-weight:700;color:#059669}.group-total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0 0;margin-top:6px;border-top:1px solid #e2e8f0;font-size:17px;font-weight:800;color:#059669}.group-total-row .gt-label{color:#1e293b;font-size:14px}.gs-title{font-size:11px;font-weight:700;color:#64748b;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.order-actions{display:flex;gap:8px;margin-top:14px}.order-actions button{flex:1;padding:10px;border-radius:12px;border:none;font-weight:700;font-size:12px;cursor:pointer;transition:all .15s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}.btn-clear{background:#f1f5f9;color:#64748b}.btn-clear:hover{background:#e2e8f0}.btn-export{background:#2563eb;color:#fff}.btn-export:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 2px 8px #2563eb33}.btn-place-order{width:100%;margin-top:10px;padding:12px;border-radius:12px;border:none;background:linear-gradient(135deg,#059669,#10b981);color:#fff;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s;box-shadow:0 4px 16px #05966940}.btn-place-order:hover{transform:translateY(-1px);box-shadow:0 6px 24px #05966959}.btn-place-order:active{transform:scale(.98)}.op-history-btn{background:none;border:none;color:#94a3b8;cursor:pointer;width:30px;height:30px;border-radius:8px;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}.op-history-btn:hover{background:#f1f5f9;color:#1e293b}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f1b2d,#1a3a5f);display:flex;align-items:center;justify-content:center;z-index:1000}.login-card{background:#fff;border-radius:24px;padding:40px 36px;width:400px;max-width:92vw;box-shadow:0 24px 80px #0000004d;animation:popIn .35s ease}@keyframes popIn{0%{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.login-card h2{font-size:24px;font-weight:800;text-align:center;margin-bottom:4px}.login-card h2 i{color:#fbbf24;margin-right:8px}.login-card .login-sub{text-align:center;font-size:14px;color:#94a3b8;margin-bottom:28px}.login-card label{font-size:12px;font-weight:600;color:#475569;display:block;margin-bottom:6px}.login-card input[type=text]{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid #e2e8f0;font-size:15px;font-family:inherit;outline:none;transition:all .2s;margin-bottom:16px}.login-card input[type=text]:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.login-card .btn-primary{width:100%;padding:14px;border-radius:14px;border:none;background:#2563eb;color:#fff;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px}.login-card .btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 16px #2563eb33}.login-card .btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.login-card .divider{text-align:center;font-size:12px;color:#94a3b8;margin:20px 0;position:relative}.login-card .divider:before,.login-card .divider:after{content:"";position:absolute;top:50%;width:42%;height:1px;background:#e2e8f0}.login-card .divider:before{left:0}.login-card .divider:after{right:0}.login-card .join-row{display:flex;gap:8px}.login-card .join-row input{flex:1;margin-bottom:0;text-transform:uppercase;letter-spacing:4px;font-weight:800;text-align:center;font-size:18px}.login-card .join-row button{padding:14px 20px;border-radius:14px;border:none;background:linear-gradient(135deg,#059669,#10b981);color:#fff;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;transition:all .15s}.login-card .join-row button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0596694d}.login-card .login-error{color:#ef4444;font-size:12px;font-weight:600;margin-bottom:12px;text-align:center;background:#fef2f2;padding:8px 12px;border-radius:8px}.login-card .my-name-hint{font-size:11px;color:#94a3b8;margin-top:-10px;margin-bottom:16px;display:flex;align-items:center;gap:6px}.login-footer-links{text-align:center;margin-top:12px;padding-top:14px;border-top:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease}.modal-box{background:#fff;border-radius:24px;max-width:440px;width:100%;overflow:hidden;animation:modalSlideUp .3s ease;box-shadow:0 24px 80px #0003}.modal-header{background:linear-gradient(135deg,#0f4c3a,#1a7a5e);color:#fff;padding:20px 24px;display:flex;align-items:center;gap:10px}.modal-header h2{font-size:18px;font-weight:700;flex:1}.modal-header i:first-child{font-size:22px;color:#fbbf24}.modal-close{background:#ffffff26;border:none;color:#fff;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:.2s}.modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-body{padding:24px}.qr-code-wrap{display:flex;justify-content:center;padding:20px 0}.qr-link{text-align:center;padding:12px 0}.qr-link a{color:#059669;font-weight:600;text-decoration:none;font-size:13px;word-break:break-all}.qr-link a:hover{text-decoration:underline}.modal-privacy-content{font-size:13px;color:#475569;line-height:1.7}.modal-privacy-content h3{font-size:15px;color:#1e293b;margin:20px 0 8px;display:flex;align-items:center;gap:8px}.modal-privacy-content h3 i{color:#059669;font-size:14px}.modal-privacy-content ul{padding-left:20px;margin:8px 0}.modal-privacy-content li{margin-bottom:6px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:99999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:14px 22px;border-radius:14px;font-size:13px;font-weight:600;box-shadow:0 8px 32px #00000026;pointer-events:auto;animation:toastIn .3s ease;max-width:380px;display:flex;align-items:center;gap:10px}.toast i{font-size:14px}.toast-add{background:#065f46;color:#fff}.toast-remove{background:#991b1b;color:#fff}.toast-update{background:#1e40af;color:#fff}.toast-info{background:#1e293b;color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1400px){.layout{padding:20px 24px}.persons-bar{padding:10px 24px}header{padding:14px 24px}}@media(max-width:1100px){.layout{grid-template-columns:1fr 320px;padding:16px 20px;gap:16px}header{padding:12px 20px}.persons-bar{padding:8px 20px}.menu-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:860px){body{overflow-x:hidden}.layout{grid-template-columns:1fr;padding:10px 10px 80px;gap:10px}header{padding:8px 12px;gap:6px}header h1{font-size:15px;gap:4px}header h1 i{font-size:15px}header .header-meta{display:none}header .header-left{gap:6px}.code-badge{font-size:12px;padding:3px 10px;letter-spacing:1px}.code-badge i{display:none}.header-btn{width:28px;height:28px;font-size:12px;border-radius:7px}.leave-btn{padding:4px 8px;font-size:10px}.leave-btn span{display:none}.persons-bar{padding:6px 12px;gap:5px}.person-chip{font-size:11px;padding:4px 10px;gap:3px}.add-person-btn{font-size:10px;padding:4px 10px}.cats{margin-bottom:8px}.cat-btn{padding:5px 10px;font-size:11px;gap:4px}.cat-btn i{font-size:9px}.search-bar{padding:6px 10px;border-radius:8px;margin-bottom:10px}.search-bar input{font-size:13px}.menu-grid{grid-template-columns:repeat(2,1fr);gap:6px}.menu-grid .menu-card{padding:10px}.menu-card .item-name{font-size:11px}.menu-card .item-price{font-size:12px;margin-top:3px;padding-top:3px}.section-title{font-size:10px;padding:6px 0;margin:8px 0 6px}.order-panel{display:none}.login-card{padding:24px 20px}.login-card h2{font-size:18px}.modal-overlay{padding:0;align-items:flex-end}.modal-box{border-radius:24px 24px 0 0;max-width:100%}.toast-container{bottom:80px;right:10px;left:10px}.toast{max-width:100%;font-size:11px;padding:10px 14px}}@media(max-width:480px){.layout{padding:8px 8px 70px;gap:8px}header{padding:6px 10px;gap:4px}header h1{font-size:14px}.code-badge{font-size:11px;padding:2px 8px}.header-btn{width:26px;height:26px;font-size:11px}.menu-grid{gap:5px}.menu-grid .menu-card{padding:8px}.menu-card .item-name{font-size:10px}.cat-btn{padding:4px 8px;font-size:10px}.cat-btn i+span{display:none}}.mobile-fab{position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#059669,#10b981);color:#fff;border:none;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #05966966;cursor:pointer;z-index:60;animation:fabIn .3s ease;transition:transform .15s,box-shadow .15s}.mobile-fab:active{transform:scale(.92);box-shadow:0 2px 8px #05966940}.mobile-fab-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #ef444459;padding:0 5px}@keyframes fabIn{0%{opacity:0;transform:scale(0) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.mobile-order-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;z-index:100;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.mobile-order-header{display:flex;align-items:center;gap:10px;padding:14px 16px;background:linear-gradient(135deg,#0f1b2d,#1e3a5f,#2d6a9f);color:#fff;flex-shrink:0}.mobile-order-header .op-avatar{width:32px;height:32px;background:#ffffff26;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.mobile-order-header h2{font-size:16px;font-weight:700;flex:1}.mobile-order-header .op-count{background:#fbbf24;color:#1e293b;font-size:12px;padding:2px 10px;border-radius:100px;font-weight:700}.mobile-order-close{width:34px;height:34px;border-radius:50%;background:#ffffff1f;border:none;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.mobile-order-close:hover{background:#ffffff40}.mobile-order-body{flex:1;overflow-y:auto;padding:8px 14px;display:flex;flex-direction:column;gap:6px}.mobile-order-body .order-item{background:#f8fafc;border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:10px;border:1px solid #e2e8f0}.mobile-order-footer{flex-shrink:0;padding:12px 16px env(safe-area-inset-bottom,12px);border-top:1px solid #e2e8f0;background:#fafbfc}.mobile-order-total{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:#1e293b}.mob-total-price{font-weight:800;color:#059669;font-size:17px}.mobile-order-actions{display:flex;gap:8px;margin-top:10px}.mobile-order-actions button{flex:1;padding:11px;border-radius:12px;border:none;font-weight:700;font-size:12px;cursor:pointer;transition:all .15s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}.mob-btn-export{background:#2563eb;color:#fff}.mob-btn-export:hover{background:#1d4ed8}.order-view-box{max-width:520px}.order-view-body{padding:0;max-height:70vh;overflow-y:auto}.ov-header{padding:16px 20px;font-size:12px;color:#64748b;border-bottom:1px solid #e2e8f0;font-weight:600;background:#f8fafc}.ov-section{padding:12px 0;margin:0 20px;border-bottom:1px solid #f1f5f9}.ov-section:last-child{border-bottom:none}.ov-section:first-child{margin-top:0}.ov-section-title{font-size:12px;font-weight:700;color:#2563eb;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.ov-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0;gap:8px}.ov-item-name{font-size:13px;color:#1e293b;flex:1;min-width:0}.ov-item-code{font-size:10px;color:#94a3b8;font-weight:700;margin-right:4px}.ov-item-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.ov-item-qty{font-size:11px;color:#94a3b8;font-weight:600}.ov-item-sub{font-size:13px;font-weight:700;color:#059669;min-width:50px;text-align:right}.ov-total{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:2px solid #e2e8f0;margin:0}.ov-total-label{font-size:15px;font-weight:700;color:#1e293b}.ov-total-price{font-size:22px;font-weight:800;color:#059669}.ov-total-sub{font-size:12px;color:#94a3b8;text-align:right;padding:0 20px 16px;margin-top:-8px}.oh-card{border-bottom:1px solid #f1f5f9}.oh-card:last-child{border-bottom:none}.oh-card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;cursor:pointer;transition:background .1s;gap:8px}.oh-card-header:hover{background:#f8fafc}.oh-card-left{display:flex;align-items:center;gap:10px}.oh-order-num{font-size:14px;font-weight:800;color:#2563eb;background:#eff6ff;padding:2px 10px;border-radius:6px}.oh-order-date{font-size:11px;color:#94a3b8;font-weight:500}.oh-card-right{display:flex;align-items:center;gap:10px}.oh-order-summary{font-size:11px;color:#94a3b8;font-weight:500}.oh-order-total{font-size:15px;font-weight:800;color:#059669}.oh-card-body{padding:0 20px 12px}.oh-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0;gap:8px}.oh-item-left{flex:1;min-width:0}.oh-item-person{font-size:10px;font-weight:700;color:#3b82f6;background:#eff6ff;padding:1px 7px;border-radius:4px;margin-right:6px}.oh-item-name{font-size:12px;color:#1e293b}.oh-item-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.oh-item-qty{font-size:11px;color:#94a3b8;font-weight:600}.oh-item-sub{font-size:12px;font-weight:700;color:#059669;min-width:45px;text-align:right}.oh-paid-by{font-size:11px;color:#64748b;padding:6px 0 10px;margin-bottom:6px;border-bottom:1px dashed #e2e8f0;display:flex;align-items:center;gap:5px}.oh-paid-by i{color:#f59e0b}.history-panel{background:#fff;border-radius:20px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:0 4px 20px #0000000f;margin-top:16px}.history-header{display:flex;align-items:center;gap:8px;padding:14px 18px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;font-weight:700;color:#475569;transition:background .1s}.history-header:hover{background:#f8fafc}.history-header i:first-child{color:#94a3b8;font-size:14px}.history-header span{flex:1}.history-body{border-top:1px solid #e2e8f0;max-height:400px;overflow-y:auto}.hp-card{border-bottom:1px solid #f1f5f9}.hp-card:last-child{border-bottom:none}.hp-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 18px;cursor:pointer;gap:6px;transition:background .1s}.hp-card-header:hover{background:#f8fafc}.hp-card-left{display:flex;align-items:center;gap:8px;min-width:0}.hp-order-num{font-size:12px;font-weight:800;color:#2563eb;background:#eff6ff;padding:1px 8px;border-radius:5px}.hp-order-payer{font-size:10px;color:#94a3b8;font-weight:600;display:flex;align-items:center;gap:3px}.hp-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.hp-order-total{font-size:14px;font-weight:800;color:#059669}.hp-card-body{padding:0 18px 10px}.hp-item{display:flex;align-items:center;gap:4px;padding:3px 0;font-size:11px}.hp-item-person{font-weight:700;color:#3b82f6;background:#eff6ff;padding:1px 6px;border-radius:4px;font-size:9px;white-space:nowrap}.hp-item-name{flex:1;min-width:0;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-item-code{font-size:9px;color:#94a3b8;font-weight:700;margin-right:2px}.hp-item-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.hp-item-qty{font-size:10px;color:#94a3b8}.hp-item-sub{font-size:11px;font-weight:700;color:#059669;min-width:35px;text-align:right}.hp-total{display:flex;justify-content:space-between;align-items:center;padding:10px 18px;border-top:1px solid #e2e8f0;font-size:12px;font-weight:600;color:#475569}.hp-total-price{font-size:16px;font-weight:800;color:#059669}@media(max-width:860px){.history-panel{margin-top:12px;border-radius:16px}.history-panel .history-body{max-height:300px}}.liquidacion-box{max-width:520px}.liquidacion-body{padding:0;max-height:70vh;overflow-y:auto}.sw-header{padding:16px 20px;font-size:13px;color:#64748b;border-bottom:1px solid #e2e8f0;font-weight:700;background:linear-gradient(135deg,#0f1b2d,#1e3a5f);color:#94a3b8}.sw-header .sw-session{color:#e2e8f0}.sw-person{padding:14px 20px;border-bottom:1px solid #f1f5f9}.sw-person:last-child{border-bottom:none}.sw-person-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.sw-person-name{font-size:14px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:6px}.sw-person-name i{color:#3b82f6;font-size:12px}.sw-person-total{font-size:16px;font-weight:800;color:#059669}.sw-item{display:flex;justify-content:space-between;align-items:center;padding:2px 0 2px 22px;gap:8px}.sw-item-name{font-size:12px;color:#475569;flex:1}.sw-item-price{font-size:12px;font-weight:600;color:#64748b}.sw-summary{padding:14px 20px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.sw-summary-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;color:#475569}.sw-summary-row.total{border-bottom:1px solid #e2e8f0;padding-bottom:8px;margin-bottom:4px}.sw-summary-value{font-weight:700;color:#1e293b}.sw-summary-row.total .sw-summary-value{font-size:18px;font-weight:800;color:#059669}.sw-settlements{margin:14px 20px;border:1px solid #fbbf24;border-radius:12px;padding:14px;background:#fffbeb}.sw-settlements-title{font-size:13px;font-weight:700;color:#d97706;margin-bottom:10px;display:flex;align-items:center;gap:6px}.sw-settlement{display:flex;align-items:center;gap:6px;padding:5px 0;font-size:13px}.sw-sett-from{font-weight:700;color:#dc2626;min-width:60px}.sw-sett-arrow{color:#94a3b8;font-weight:300}.sw-sett-to{font-weight:700;color:#16a34a;min-width:60px}.sw-sett-amount{margin-left:auto;font-weight:800;color:#1e293b;font-size:15px}.sw-sett-note{margin-top:8px;font-size:11px;color:#92400e;display:flex;align-items:center;gap:4px}.sw-actions{display:flex;gap:10px;padding:16px 20px;border-top:1px solid #e2e8f0}.sw-btn{flex:1;padding:12px;border-radius:12px;border:2px solid #1e293b;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;background:#1e293b;color:#fff;transition:all .15s}.sw-btn:hover{background:#334155}.sw-btn.copied{background:#059669;border-color:#059669}.sw-btn-csv{background:#fff;color:#1e293b;border-color:#cbd5e1}.sw-btn-csv:hover{background:#f1f5f9;border-color:#94a3b8}.sw-btn-csv.copied{background:#059669;border-color:#059669;color:#fff}@media(max-width:480px){.sw-person{padding:10px 14px}.sw-item{padding-left:16px}.sw-summary{padding:10px 14px}.sw-settlements{margin:10px 14px;padding:10px}.sw-actions{flex-direction:column;gap:8px;padding:12px 14px}}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:10001;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.admin-modal{background:#fff;border-radius:24px;max-width:860px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideUp .3s ease}.admin-header{background:linear-gradient(135deg,#0f4c3a,#1a7a5e);color:#fff;padding:24px 32px;border-radius:24px 24px 0 0;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:1}.admin-header i:first-child{font-size:28px;color:#6ee7b7}.admin-header h2{font-size:22px;font-weight:700;flex:1}.admin-close{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.2s}.admin-close:hover{background:#ffffff4d}.admin-tabs{display:flex;gap:0;background:#f1f5f9;border-bottom:1px solid #e2e8f0;position:sticky;top:76px;z-index:1}.admin-tab{flex:1;padding:14px 16px;border:none;background:transparent;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;font-family:inherit;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;border-bottom:2px solid transparent}.admin-tab:hover{color:#1e293b;background:#00000005}.admin-tab.active{color:#0f4c3a;border-bottom-color:#059669;background:#fff}.admin-tab-logout{flex:0 0 auto;padding:14px;color:#ef4444}.admin-tab-logout:hover{color:#dc2626!important}.ban-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:100px;line-height:1.4}.admin-body{padding:24px 32px 32px}.admin-loading,.admin-error{text-align:center;padding:40px 0;font-size:14px;color:#64748b}.admin-error{color:#ef4444}.admin-note{background:#ecfdf5;border:1px solid #6ee7b7;border-radius:12px;padding:12px 16px;font-size:12px;color:#065f46;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-weight:500}.admin-note i{font-size:16px}.admin-login{text-align:center;padding:40px 20px;max-width:380px;margin:0 auto}.admin-login-icon{width:64px;height:64px;background:#f1f5f9;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px;color:#64748b}.admin-login h3{font-size:20px;font-weight:700;margin-bottom:8px}.admin-login-desc{font-size:13px;color:#64748b;margin-bottom:24px}.admin-login-input{width:100%;padding:12px 16px;border:1.5px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:inherit;outline:none;transition:border-color .15s;text-align:center;margin-bottom:12px}.admin-login-input:focus{border-color:#059669}.admin-login-error{font-size:13px;color:#ef4444;font-weight:600;margin-bottom:12px}.admin-login-btn{width:100%;padding:12px 24px;border:none;border-radius:12px;background:linear-gradient(135deg,#0f4c3a,#1a7a5e);color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:8px}.admin-login-btn:hover{opacity:.9}.admin-login-btn:disabled{opacity:.5;cursor:not-allowed}.admin-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.metric-card{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-radius:16px;padding:18px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;border:1px solid #bbf7d0}.metric-icon{font-size:22px;color:#059669}.metric-value{font-size:28px;font-weight:800;color:#065f46;line-height:1}.metric-label{font-size:11px;color:#6b7280;font-weight:500}.admin-section{margin-bottom:24px;padding:16px 20px;background:#f8fafc;border-radius:16px;border:1px solid #e2e8f0}.admin-section h3{font-size:15px;font-weight:700;color:#1e293b;margin-bottom:14px;display:flex;align-items:center;gap:8px}.admin-section h3 i{color:#059669;font-size:15px}.admin-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;font-size:13px}.admin-row span:first-child{flex:0 0 160px;color:#475569;font-weight:500}.admin-row .admin-val{flex:0 0 60px;text-align:right;font-weight:700;color:#1e293b}.admin-bar-bg{flex:1;height:20px;background:#e2e8f0;border-radius:10px;overflow:hidden}.admin-bar{height:100%;background:linear-gradient(90deg,#059669,#10b981);border-radius:10px;transition:width .5s ease;min-width:4px}.cat-bar{background:linear-gradient(90deg,#2563eb,#3b82f6)}.admin-hourly-grid{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;height:120px;align-items:end;margin-top:8px}.hour-bar-wrap{display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.hour-bar{width:100%;background:linear-gradient(180deg,#059669,#10b981);border-radius:2px 2px 0 0;min-height:2px;transition:height .3s ease;cursor:help}.hour-label{font-size:8px;color:#94a3b8;margin-top:2px}.admin-footer{background:#f1f5f9;border-radius:16px;padding:14px 20px;display:flex;flex-direction:column;gap:6px}.admin-footer p{font-size:12px;color:#64748b;display:flex;align-items:center;gap:8px;font-weight:500}.admin-footer p i{color:#059669;width:14px;text-align:center}.ban-form{display:flex;flex-direction:column;gap:8px}.ban-input{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:13px;font-family:JetBrains Mono,Courier New,monospace;outline:none;transition:border-color .15s;background:#fff}.ban-input:focus{border-color:#059669}.ban-input-reason{font-family:inherit}.ban-btn{padding:10px 20px;border:none;border-radius:10px;background:#ef4444;color:#fff;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;transition:background .15s;display:flex;align-items:center;gap:8px;justify-content:center}.ban-btn:hover{background:#dc2626}.ban-btn:disabled{opacity:.4;cursor:not-allowed}.ban-msg{margin-top:10px;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600}.ban-msg-ok{background:#ecfdf5;color:#065f46}.ban-msg-err{background:#fef2f2;color:#991b1b}.ban-desc{font-size:12px;color:#64748b;margin-top:8px;display:flex;align-items:flex-start;gap:6px;line-height:1.5}.ban-desc i{margin-top:2px;flex-shrink:0}.ban-check-btn{padding:10px 18px;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;color:#475569;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;transition:all .15s;display:inline-flex;align-items:center;gap:8px}.ban-check-btn:hover{border-color:#059669;color:#065f46;background:#f0fdf4}.ban-check-result{margin-top:10px;padding:10px 14px;border-radius:10px;font-size:13px;display:flex;flex-direction:column;gap:6px}.ban-check-result.banned{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.ban-check-result.not-banned{background:#f0fdf4;border:1px solid #bbf7d0;color:#065f46}.ban-check-ip{font-size:11px;color:#64748b}.ban-check-ip code{background:#e2e8f0;padding:1px 6px;border-radius:4px;font-size:11px;font-family:monospace}.ban-count{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:100px;margin-left:4px}.ban-empty{font-size:13px;color:#64748b;text-align:center;padding:12px 0;display:flex;align-items:center;justify-content:center;gap:8px}.ban-list{display:flex;flex-direction:column;gap:8px}.ban-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;transition:box-shadow .15s}.ban-item:hover{box-shadow:0 2px 8px #0000000f}.ban-item.auto{border-left:3px solid #f59e0b}.ban-item.manual{border-left:3px solid #ef4444}.ban-item-left{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.ban-ip code{font-size:13px;font-weight:700;color:#1e293b;font-family:JetBrains Mono,Courier New,monospace;background:#f1f5f9;padding:2px 8px;border-radius:5px}.ban-reason{font-size:12px;color:#475569}.ban-meta{font-size:11px;color:#94a3b8;display:flex;align-items:center;gap:4px}.ban-meta i{font-size:10px}.ban-unban-btn{background:none;border:1px solid #e2e8f0;border-radius:8px;width:34px;height:34px;cursor:pointer;font-size:14px;color:#059669;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.ban-unban-btn:hover{background:#f0fdf4;border-color:#059669}.admin-menus{padding:0}.menu-create-form{display:flex;flex-direction:column;gap:8px;margin:12px 0}.menu-input{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s;background:#fff}.menu-input:focus{border-color:#059669;box-shadow:0 0 0 3px #0596691a}.menu-create-btn{padding:10px 18px;border:none;border-radius:10px;background:linear-gradient(135deg,#059669,#047857);color:#fff;font-weight:600;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:opacity .15s}.menu-create-btn:hover{opacity:.9}.menu-create-btn:disabled{opacity:.4;cursor:not-allowed}.menu-list{display:flex;flex-direction:column;gap:8px}.menu-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;transition:box-shadow .15s}.menu-card:hover{box-shadow:0 2px 8px #0000000f}.menu-card.active-menu{border-color:#86efac;background:#f0fdf4}.menu-card-left{flex:1;min-width:0}.menu-card-name{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.menu-card-name strong{font-size:14px;color:#1e293b}.menu-active-badge{color:#059669;font-size:16px}.menu-slug code{font-size:11px;color:#64748b;background:#f1f5f9;padding:1px 6px;border-radius:4px}.menu-card-desc{font-size:12px;color:#64748b;margin-top:2px}.menu-card-meta{font-size:11px;color:#94a3b8;margin-top:2px}.menu-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.menu-activate-btn{padding:6px 14px;border:1.5px solid #86efac;border-radius:8px;background:#f0fdf4;color:#059669;font-weight:600;font-size:12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:4px}.menu-activate-btn:hover{background:#059669;color:#fff;border-color:#059669}.menu-active-label{font-size:11px;font-weight:700;color:#059669;background:#d1fae5;padding:4px 10px;border-radius:100px}.menu-delete-btn{background:none;border:1px solid #e2e8f0;border-radius:8px;width:32px;height:32px;cursor:pointer;font-size:13px;color:#ef4444;display:flex;align-items:center;justify-content:center;transition:all .15s}.menu-delete-btn:hover{background:#fef2f2;border-color:#fca5a5}@media(max-width:640px){.admin-overlay{padding:0;align-items:flex-end}.admin-modal{max-height:100vh;border-radius:24px 24px 0 0;max-width:100%}.admin-body{padding:16px 16px 24px}.admin-header{padding:18px 20px;position:sticky;top:0}.admin-tabs{top:64px;overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab{font-size:12px;padding:12px 10px;white-space:nowrap;flex:0 0 auto}.admin-metrics{grid-template-columns:repeat(2,1fr);gap:8px}.metric-card{padding:14px 10px}.metric-value{font-size:22px}.admin-section{padding:14px}.admin-section h3{font-size:14px}.admin-row span:first-child{flex:0 0 100px;font-size:12px}.admin-row .admin-val{flex:0 0 50px;font-size:12px}.admin-footer{padding:12px 14px}.admin-login{padding:24px 16px}.menu-card{flex-direction:column;gap:8px;padding:12px}.menu-card-right{align-self:flex-end}.menu-active-label{font-size:10px;padding:3px 8px}.ban-form{gap:6px}.ban-item{flex-direction:column;gap:8px;padding:10px 12px}.ban-item-left{width:100%}.ban-unban-btn{align-self:flex-end}.admin-hourly-grid{height:80px}.hour-label{font-size:7px}}.landing-hero{background:linear-gradient(135deg,#0f4c3a,#1a7a5e,#2d6a9f);color:#fff;padding:100px 24px 90px;text-align:center;position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,.06) 0%,transparent 50%);pointer-events:none}.landing-hero-inner{max-width:720px;margin:0 auto;position:relative;z-index:1}.landing-hero-icon{font-size:48px;color:#fbbf24;margin-bottom:20px}.landing-hero h1{font-size:clamp(32px,6vw,52px);font-weight:800;letter-spacing:-1px;margin-bottom:16px}.landing-hero h1 i{color:#fbbf24}.landing-hero p{font-size:18px;opacity:.85;max-width:600px;margin:0 auto 32px;line-height:1.7}.landing-hero-badge{display:inline-block;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);padding:6px 16px;border-radius:100px;font-size:13px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);margin-bottom:24px}.landing-container{max-width:960px;margin:0 auto;padding:0 28px}.landing-section{padding:72px 0}.landing-section h2{font-size:30px;font-weight:800;text-align:center;margin-bottom:48px;letter-spacing:-.5px}.landing-section h2 i{color:#059669;margin-right:10px}.landing-features{background:#fff}.landing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:24px}.landing-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:32px 26px 30px;text-align:center;transition:transform .2s,box-shadow .2s}.landing-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000000f}.landing-card-icon{width:56px;height:56px;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:24px;color:#059669}.landing-card h3{font-size:18px;font-weight:700;margin-bottom:8px}.landing-card p{font-size:14px;color:#64748b}.landing-how{background:#f8fafc;position:relative}.landing-how:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:80%;max-width:600px;height:1px;background:linear-gradient(90deg,transparent,#cbd5e1,transparent)}.landing-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:28px}.landing-step{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:32px 24px 28px;text-align:center}.landing-step-num{width:40px;height:40px;background:linear-gradient(135deg,#0f4c3a,#1a7a5e);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;margin:0 auto 14px}.landing-step h3{font-size:17px;font-weight:700;margin-bottom:6px}.landing-step p{font-size:13px;color:#64748b}.landing-legal{background:#fff;position:relative}.landing-legal:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:80%;max-width:600px;height:1px;background:linear-gradient(90deg,transparent,#cbd5e1,transparent)}.landing-legal-box{background:#fffbeb;border:1px solid #fde68a;border-radius:16px;padding:32px 36px;text-align:center;max-width:700px;margin:0 auto}.landing-legal-box i{font-size:32px;color:#f59e0b;margin-bottom:12px}.landing-legal-box h3{font-size:18px;font-weight:700;margin-bottom:8px}.landing-legal-box p{font-size:14px;color:#92400e;line-height:1.7}.landing-cta{display:inline-block;background:#fff;color:#0f4c3a;padding:14px 36px;border-radius:12px;font-size:16px;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 16px #0000001a}.landing-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.landing-cta i{margin-right:8px}.landing-footer{background:#1e293b;color:#94a3b8;padding:48px 24px 44px;text-align:center}.landing-footer-inner{max-width:600px;margin:0 auto}.landing-footer-icon{font-size:28px;color:#fbbf24;margin-bottom:8px}.landing-footer h3{color:#fff;font-size:18px;font-weight:700;margin-bottom:4px}.landing-footer p{font-size:13px;margin-bottom:4px}.landing-footer a{color:#6ee7b7;text-decoration:none;font-weight:600}.landing-footer a:hover{text-decoration:underline}.landing-footer-divider{width:40px;height:2px;margin:12px auto;background:#ffffff14;border-radius:2px}.landing-oss-box{max-width:400px;margin:16px auto 12px;background:#6ee7b70f;border:1px solid rgba(110,231,183,.12);border-radius:12px;padding:16px 20px;font-size:13px}.landing-oss-box i{font-size:20px;color:#6ee7b7;margin-bottom:6px;display:block}.landing-oss-box p{margin:4px 0;color:#94a3b8}.landing-oss-box a{color:#6ee7b7;font-weight:600}.landing-oss-box a:hover{text-decoration:underline}.landing-screenshots-section{background:#fff;position:relative}.landing-screenshots-section:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:80%;max-width:600px;height:1px;background:linear-gradient(90deg,transparent,#cbd5e1,transparent)}.landing-screenshots{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin:0}.landing-screenshot{flex:1;min-width:280px;max-width:500px;border-radius:14px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#00000005;transition:transform .2s,box-shadow .2s}.landing-screenshot:hover{transform:translateY(-3px);box-shadow:0 12px 40px #0000001f}.landing-screenshot img{width:100%;display:block}.landing-screenshot-label{padding:12px 16px 14px;font-size:13px;color:#475569;font-weight:600;background:#f1f5f9;border-top:1px solid #e2e8f0}.screenshot-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000d9;display:flex;align-items:center;justify-content:center;animation:screenshot-fade-in .15s ease-out}@keyframes screenshot-fade-in{0%{opacity:0}to{opacity:1}}@keyframes screenshot-zoom-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.screenshot-modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;border:none;background:#ffffff1f;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:10}.screenshot-modal-close:hover{background:#ffffff40}.screenshot-modal-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:none;background:#ffffff1a;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:10}.screenshot-modal-nav:hover{background:#ffffff38}.screenshot-modal-prev{left:20px}.screenshot-modal-next{right:20px}.screenshot-modal-content{max-width:92vw;max-height:90vh;display:flex;flex-direction:column;animation:screenshot-zoom-in .2s ease-out}.screenshot-modal-content img{max-width:92vw;max-height:82vh;object-fit:contain;border-radius:12px;display:block;box-shadow:0 8px 40px #00000080}.screenshot-modal-label{text-align:center;margin-top:14px;font-size:15px;font-weight:600;color:#e2e8f0}.screenshot-modal-counter{position:absolute;bottom:24px;left:50%;transform:translate(-50%);font-size:13px;color:#94a3b8;letter-spacing:.5px;background:#00000080;padding:5px 14px;border-radius:20px}@media(max-width:640px){.landing-hero{padding:72px 20px 64px}.landing-hero h1{margin-bottom:12px}.landing-hero p{font-size:16px;margin-bottom:24px}.landing-section{padding:48px 0}.landing-section h2{font-size:24px;margin-bottom:32px}.landing-container{padding:0 20px}.landing-card,.landing-step,.landing-legal-box{padding:24px 20px}.landing-footer{padding:36px 20px 32px}.screenshot-modal-prev{left:8px;width:40px;height:40px;font-size:16px}.screenshot-modal-next{right:8px;width:40px;height:40px;font-size:16px}}
