:root{--ink:#143334;--muted:#6f7f7d;--cream:#f7f5ef;--paper:#fff;--green:#1d6b5d;--green2:#2e8b72;--lime:#ddefb7;--coral:#f08a73;--line:#dfe6e2;--shadow:0 16px 45px rgba(23,63,63,.1);--radius:22px}
*{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{margin:0;background:var(--cream);color:var(--ink);font-family:"DM Sans","Segoe UI",sans-serif;line-height:1.45}button,input,select{font:inherit}a{color:inherit;text-decoration:none}button{cursor:pointer}.shell{width:min(1180px,calc(100% - 40px));margin:auto}.page-content{padding:42px 0 110px}.topbar{height:78px;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;backdrop-filter:blur(16px)}.topbar-inner{height:100%;display:flex;align-items:center;gap:34px}.brand{display:flex;align-items:center;gap:11px;min-width:175px}.brand-mark{width:40px;height:40px;border-radius:13px;background:var(--ink);color:#fff;display:inline-grid;place-items:center;font:bold 22px "Manrope";box-shadow:inset 0 -4px 0 rgba(0,0,0,.12)}.brand-mark.large{width:62px;height:62px;border-radius:20px;font-size:32px}.brand>span:last-child{display:flex;flex-direction:column}.brand strong{font:800 20px "Manrope";letter-spacing:-.7px}.brand small,.user-menu small{font-size:11px;color:var(--muted)}.desktop-nav{display:flex;gap:8px;flex:1}.desktop-nav a{font-weight:600;font-size:14px;padding:10px 13px;border-radius:12px}.desktop-nav a:hover{background:#eaf2ed}.user-menu{display:flex;align-items:center;gap:9px}.user-menu>div{display:flex;flex-direction:column}.avatar{width:37px;height:37px;border-radius:50%;display:grid;place-items:center;background:var(--lime);font-weight:800}.logout,.icon-btn{border:0;background:transparent;font-size:20px;color:var(--muted)}.mobile-nav{display:none}
h1,h2,h3{font-family:"Manrope",sans-serif;line-height:1.12;margin:0 0 10px;letter-spacing:-.035em}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.25rem,3vw,1.8rem)}h3{font-size:1.15rem}p{margin:0 0 16px}.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:800;color:var(--green2);margin-bottom:9px}.muted{color:var(--muted)}.hero{background:var(--ink);color:#fff;border-radius:32px;padding:42px 46px;display:flex;align-items:flex-end;justify-content:space-between;position:relative;overflow:hidden;box-shadow:var(--shadow)}.hero:after{content:"";position:absolute;width:290px;height:290px;border-radius:50%;right:15%;top:-140px;background:rgba(221,239,183,.12)}.hero h1{font-size:clamp(2rem,4vw,3.2rem)}.hero p:not(.eyebrow){color:#c9d8d4}.hero .eyebrow{color:var(--lime)}.btn{border:0;border-radius:14px;padding:13px 20px;display:inline-flex;justify-content:center;align-items:center;gap:10px;font-weight:700;min-height:48px;transition:.2s}.btn:hover{transform:translateY(-1px)}.btn.primary{background:var(--green);color:#fff;box-shadow:0 8px 20px rgba(29,107,93,.2)}.btn.secondary{background:#e3ece7;color:var(--ink)}.btn.light{background:#fff;color:var(--ink);position:relative;z-index:1}.btn.ghost{background:transparent;border:1px solid var(--line)}.btn.wide{width:100%}.btn.compact{min-height:40px;padding:8px 16px}.text-link{font-weight:700;color:var(--green);display:inline-block}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0 46px}.stat-card{background:#fff;padding:22px;border-radius:20px;display:flex;align-items:center;gap:15px;border:1px solid rgba(20,51,52,.06)}.stat-icon{width:48px;height:48px;border-radius:15px;display:grid;place-items:center;font-size:22px}.stat-card.coral .stat-icon{background:#ffe7df}.stat-card.green .stat-icon{background:#def2e4}.stat-card.blue .stat-icon{background:#e3eef8}.stat-card>div{display:flex;flex-direction:column}.stat-card strong{font:800 27px "Manrope"}.stat-card span:last-child{font-size:13px;color:var(--muted)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin:25px 0 15px}.section-head>span{color:var(--muted);font-size:13px}.empty-state{background:#fff;border:1px dashed #cbd8d2;border-radius:var(--radius);padding:55px 20px;text-align:center}.empty-state.compact-empty{padding:30px}.empty-illustration{font-size:48px;margin-bottom:12px}.empty-state p{color:var(--muted);max-width:500px;margin:0 auto 22px}.item-list,.list-group,.shop-category{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);margin-bottom:14px}.item-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid #edf0ee}.item-row:last-child{border:0}.mini-art{width:50px;height:50px;flex:0 0 auto;border-radius:15px;background:color-mix(in srgb,var(--item-color),white 75%);display:grid;place-items:center;font-size:24px}.item-main{display:flex;flex-direction:column;flex:1;min-width:0}.item-main strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-main span{font-size:13px;color:var(--muted)}.status{font-style:normal;border-radius:30px;padding:6px 10px;font-size:11px;font-weight:700}.status.pending{background:#fff0d6;color:#8b641f}.status.done{background:#dff2e6;color:#267148}.action-row,.sticky-actions{display:flex;gap:12px;margin-top:18px}.page-head{display:flex;justify-content:space-between;align-items:end;gap:30px;margin:7px 0 32px}.page-head p:last-child{color:var(--muted)}.search-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:7px 8px 7px 17px;display:flex;align-items:center;gap:10px}.search-box span{font-size:24px}.search-box input{border:0;outline:0;background:transparent;flex:1;min-width:0}.category-strip{display:flex;gap:9px;overflow:auto;padding:18px 2px 8px;scrollbar-width:none}.category-pill{white-space:nowrap;background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 14px;font-size:13px;font-weight:600;display:flex;gap:7px}.category-pill.active{background:var(--ink);color:#fff;border-color:var(--ink)}.catalog-section{margin-top:30px}.product-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:15px}.product-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:10px;position:relative;min-width:0;transition:.2s}.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.product-card img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:14px}.product-copy{display:flex;flex-direction:column;padding:11px 5px 50px}.product-copy strong{font-size:14px}.product-copy span{font-size:12px;color:var(--muted)}.quick-add{position:absolute;bottom:10px;left:15px;right:10px;display:flex;justify-content:space-between;align-items:center}.quick-add input{width:56px;border:1px solid var(--line);border-radius:10px;padding:7px}.round-add{width:38px;height:38px;border-radius:12px;border:0;background:var(--green);color:#fff;font-size:22px}.toast-note,.alert{padding:13px 16px;border-radius:13px;margin:0 0 18px}.toast-note{background:#dff2e6;color:#1c6544}.toast-note.error,.alert.error{background:#ffe3df;color:#952f24}.alert.demo{background:#fff2c7;color:#765b06}.list-group-head{display:flex;align-items:center;gap:10px;padding:15px 18px;background:#edf3ef}.list-group-head>span{font-size:24px}.list-group-head h2{font-size:17px;margin:0;flex:1}.list-group-head em{font-style:normal;background:#fff;border-radius:20px;padding:4px 9px;font-size:11px}.icon-btn.danger{font-size:26px;color:#b7685f}.purchased-block{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:8px 16px;margin:22px 0}.purchased-block summary{padding:10px 0;font-weight:700}.item-row.bought strong{text-decoration:line-through;color:var(--muted)}.checkmark,.buy-check{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:#dff2e6;color:var(--green);font-weight:bold}.trip-history{margin-top:30px}.trip-row{display:flex;align-items:center;gap:13px;background:#fff;border-bottom:1px solid var(--line);padding:15px 18px}.trip-row:first-of-type{border-radius:15px 15px 0 0}.trip-row:last-child{border:0;border-radius:0 0 15px 15px}.trip-row>span{font-size:24px}.trip-row>div{display:flex;flex-direction:column;flex:1}.trip-row small{color:var(--muted)}.trip-row em{font-size:11px;color:var(--green)}.sticky-actions{position:sticky;bottom:18px;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:var(--shadow);justify-content:center;z-index:5}.shop-start{max-width:540px;margin:50px auto;background:#fff;border-radius:30px;padding:45px;box-shadow:var(--shadow);text-align:center}.shop-start form{text-align:left}.shop-hero-icon{font-size:60px}.shop-top{display:flex;justify-content:space-between;align-items:end;margin-bottom:22px}.shopping-progress{height:8px;border-radius:8px;background:#e1e7e3;margin-bottom:25px;overflow:hidden}.shopping-progress span{display:block;height:100%;background:var(--green);border-radius:8px}.buy-row{display:flex;align-items:center;gap:13px;border-bottom:1px solid var(--line);padding:13px 16px}.buy-row:last-child{border:0}.buy-check{border:2px solid #b7c8c0;background:#fff;color:transparent;font-size:20px}.buy-check:hover{background:var(--green);border-color:var(--green);color:#fff}.history-list{display:grid;gap:12px}.history-card{display:grid;grid-template-columns:64px 1fr auto 20px;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 18px}.history-date{width:55px;height:55px;border-radius:15px;background:#edf3ef;display:flex;flex-direction:column;align-items:center;justify-content:center}.history-date strong{font:800 20px "Manrope"}.history-date span{text-transform:uppercase;font-size:10px}.history-card>div:nth-child(2){display:flex;flex-direction:column}.history-card>div:nth-child(2) span{color:var(--muted);font-size:13px}
.tabs{display:flex;gap:8px;border-bottom:1px solid var(--line);margin-bottom:25px;overflow:auto}.tabs a{padding:11px 16px;font-weight:700;white-space:nowrap;border-bottom:3px solid transparent}.tabs a.active{border-color:var(--green);color:var(--green)}.admin-grid{display:grid;grid-template-columns:1fr 1.65fr;gap:22px}.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}.house-row,.user-row{display:flex;align-items:center;gap:12px;padding:12px;border-radius:14px}.house-row:hover,.house-row.selected{background:#edf3ef}.house-icon{width:42px;height:42px;border-radius:13px;background:#dff0e7;display:grid;place-items:center;font-size:23px}.house-row>div,.user-row>div{display:flex;flex-direction:column;flex:1}.house-row small,.user-row small{color:var(--muted)}.user-row em{font-size:11px;background:#edf3ef;border-radius:20px;padding:5px 8px}.add-panel{border-top:1px solid var(--line);margin-top:14px;padding-top:12px}.add-panel summary{font-weight:700;color:var(--green);padding:9px}.form-stack{display:grid;gap:13px;margin-top:18px}.form-stack label{display:grid;gap:6px;font-size:13px;font-weight:700;text-align:left}.form-stack input,.form-stack select{width:100%;min-height:48px;border:1px solid #cfd9d4;border-radius:13px;padding:10px 13px;background:#fff;color:var(--ink);outline:0}.form-stack input:focus,.form-stack select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(29,107,93,.1)}.field-error{color:#a33d32;font-size:12px}.toggle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.toggle-card button{width:100%;border:2px solid transparent;background:#f3f5f3;border-radius:15px;padding:7px;display:flex;flex-direction:column;align-items:start}.toggle-card.enabled button{border-color:#79ad91;background:#ecf6f0}.toggle-card img{width:100%;aspect-ratio:2/1;object-fit:cover;border-radius:10px}.toggle-card span{font-weight:700;text-align:left;font-size:12px;padding:7px 3px 2px}.toggle-card em{font-size:10px;color:var(--muted);padding:0 3px 5px}.category-admin-list{display:grid;gap:8px}.category-admin-list>div{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding:7px}.category-admin-list img{width:55px;height:42px;object-fit:cover;border-radius:9px}.category-admin-list strong{font-size:13px;flex:1}.form-hint{font-size:12px;color:var(--muted);margin-top:15px}
.auth-body{min-height:100vh;background:#e8efe9;display:grid;place-items:center;padding:25px}.auth-shell{width:min(1040px,100%);min-height:650px;display:grid;grid-template-columns:1.2fr .8fr;background:#fff;border-radius:34px;overflow:hidden;box-shadow:0 30px 80px rgba(20,51,52,.17)}.auth-art{background:var(--ink);color:#fff;padding:60px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}.auth-art:before,.auth-art:after{content:"";position:absolute;border-radius:50%;background:rgba(221,239,183,.1)}.auth-art:before{width:420px;height:420px;right:-190px;top:-170px}.auth-art:after{width:300px;height:300px;left:-150px;bottom:-130px}.auth-art h1{font-size:clamp(2.5rem,5vw,4.6rem);margin:10px 0 22px}.auth-art>p:not(.eyebrow){color:#c2d4cf;max-width:500px}.auth-art .eyebrow{color:var(--lime);margin-top:45px}.floating-icons{display:flex;gap:14px;margin-top:45px}.floating-icons span{width:62px;height:62px;background:rgba(255,255,255,.1);border-radius:19px;display:grid;place-items:center;font-size:28px;transform:rotate(-5deg)}.floating-icons span:nth-child(2n){transform:rotate(5deg) translateY(8px)}.auth-card{padding:55px 45px;display:flex;flex-direction:column;justify-content:center}.auth-card h2{font-size:2rem}.auth-note{font-size:12px;text-align:center;color:var(--muted);margin-top:24px}.otp-wrap{width:min(480px,100%)}.otp-card{background:#fff;border-radius:30px;box-shadow:var(--shadow);text-align:center}.otp-card .brand-mark{margin:0 auto 25px}.otp-input{text-align:center;font:800 28px "Manrope";letter-spacing:.35em}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(max-width:950px){.desktop-nav{display:none}.product-grid{grid-template-columns:repeat(3,1fr)}.admin-grid{grid-template-columns:1fr}.toggle-grid{grid-template-columns:repeat(4,1fr)}.auth-shell{grid-template-columns:1fr}.auth-art{display:none}.auth-card{min-height:600px}.user-menu>div{display:none}}
@media(max-width:650px){.shell{width:min(100% - 24px,1180px)}.topbar{height:65px}.topbar-inner{justify-content:space-between}.brand small{display:none}.user-menu .logout{display:none}.page-content{padding:24px 0 110px}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:72px;background:rgba(255,255,255,.96);border-top:1px solid var(--line);display:flex;justify-content:space-around;z-index:30;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav a,.mobile-nav button{height:100%;min-width:54px;border:0;background:transparent;display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:10px;font-weight:700;gap:3px}.mobile-nav span{font-size:20px}.mobile-nav .list-nav span{width:43px;height:43px;border-radius:15px;background:var(--green);color:#fff;display:grid;place-items:center;margin-top:-20px}.hero{padding:30px 25px;display:block}.hero .btn{margin-top:15px}.stat-grid{grid-template-columns:1fr 1fr;margin:16px 0 32px}.stat-card{padding:15px}.stat-card:last-child{grid-column:1/-1}.stat-icon{width:42px;height:42px}.page-head,.shop-top{align-items:start;flex-direction:column;margin-bottom:22px}.product-grid{grid-template-columns:repeat(2,1fr);gap:10px}.product-card{border-radius:16px;padding:7px}.product-copy{padding:8px 3px 48px}.category-pill{padding:8px 11px}.action-row{flex-direction:column}.item-row{padding:12px 13px}.status{display:none}.sticky-actions{bottom:80px}.shop-start{margin:10px auto;padding:30px 22px}.history-card{grid-template-columns:55px 1fr 16px;padding:12px}.history-card .status{display:none}.toggle-grid{grid-template-columns:repeat(2,1fr)}.panel{padding:14px}.auth-body{padding:0;background:#fff;overflow-x:hidden}.auth-shell{width:100%;min-width:0;min-height:100vh;border-radius:0}.auth-card{width:100%;min-width:0;padding:35px 24px;min-height:100vh}.otp-wrap{height:100vh}.otp-card{border-radius:0;box-shadow:none}.quick-add input{width:48px}.list-group-head{padding:12px 14px}}
.logout{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:11px;padding:8px 11px;font-size:12px;font-weight:700;display:flex;align-items:center;gap:5px}.logout span{font-size:17px}.logout:hover{background:#edf3ef}
@media(max-width:650px){.user-menu form{display:none}.mobile-nav form{display:block}}
