:root{--bg: #F2F2F7;--surface: #ffffff;--surface-soft: #f5f5f5;--border: #E5E7EB;--text: #000000;--muted: #6B7280;--primary: #10B981;--primary-soft: #D1FAE5;--primary-ink: #047857;--danger: #dd3d54;--success: #1f9962;--warning: #c98908;--hero-gradient-start: #059669;--hero-gradient-end: #047857;--hero-text: #ffffff;--primary-rgb: 16 185 129;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);line-height:1.45}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{background:radial-gradient(circle at top right,var(--primary-soft) 0%,var(--bg) 38%,var(--surface-soft) 100%);color:var(--text)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:700}p{margin:0}button{border:none;font:inherit;color:inherit;background:transparent}input,select,textarea{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:15px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-soft);box-shadow:0 0 0 3px rgb(var(--primary-rgb) / .16)}input::placeholder{color:var(--muted)}.text-muted{color:var(--muted)}.text-small{font-size:14px}.mono-id{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:44px;border-radius:14px;padding:10px 16px;font-weight:600;cursor:pointer;transition:.2s ease}.btn-primary{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:48px;border-radius:16px;padding:12px 16px;background:var(--primary);color:#fff;cursor:pointer;font-weight:600;transition:background .2s ease}.btn-primary:hover:not(:disabled){background:var(--primary-ink)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:48px;border-radius:16px;padding:12px 16px;border:1px solid var(--primary-soft);background:var(--surface-soft);color:var(--primary-ink);cursor:pointer;font-weight:600;transition:.2s ease}.btn-secondary:hover:not(:disabled){background:var(--primary-soft)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:48px;border-radius:16px;padding:12px 16px;background:var(--surface-soft);color:var(--primary-ink);cursor:pointer;font-weight:600;transition:background .2s ease}.btn-ghost:hover:not(:disabled){background:var(--border)}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:42px;border-radius:12px;background:var(--danger);color:#fff;cursor:pointer}.btn-primary:disabled,.btn-secondary:disabled,.btn-danger:disabled,.btn:disabled{opacity:.55;cursor:not-allowed}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{width:100%;max-width:420px}.portal-shell{width:100%;min-height:100vh;margin:0 auto;background:var(--surface);box-shadow:0 22px 56px rgb(var(--primary-rgb) / .22);border-left:1px solid var(--border);border-right:1px solid var(--border);position:relative}.main{min-height:100vh;display:flex;flex-direction:column}.content{flex:1;padding:22px 18px calc(88px + env(safe-area-inset-bottom));overflow-y:auto}.catalog-sections{display:flex;flex-direction:column;gap:2rem}.catalog-category-title{font-size:1.15rem;margin:0 0 .35rem}.catalog-category-desc{margin:0 0 .75rem}.modal-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:40;padding:16px}@media(min-width:520px){.modal-backdrop{align-items:center}}.modal-card{width:min(100%,420px);max-height:min(90vh,640px);overflow:auto;padding:1.25rem}.field-label{display:block;font-size:12px;font-weight:600;margin:.75rem 0 .35rem;color:var(--muted)}.modal-actions{display:flex;gap:10px;margin-top:1rem;flex-wrap:wrap}.cart-actions{display:flex;flex-wrap:wrap;gap:10px}.order-line-list{list-style:none;margin:.5rem 0 0;padding:0;font-size:13px}.order-line-list li{padding:.25rem 0}.order-line-list--mobile{margin-top:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.order-items-subrow td{padding-top:0;padding-bottom:.75rem;border-top:none}.product-id-chip{display:inline-block;margin-right:6px;opacity:.85}.mobile-hero{background:linear-gradient(145deg,var(--hero-gradient-start) 0%,var(--hero-gradient-end) 100%);color:var(--hero-text);border-bottom-left-radius:32px;border-bottom-right-radius:32px;padding:20px 18px 28px;min-height:140px;display:flex;flex-direction:column;justify-content:space-between}.mobile-hero-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.mobile-hero-business{font-size:14px;font-weight:600;opacity:.95}.business-switcher{position:relative}.business-switcher-mobile{max-width:calc(100% - 44px);min-width:0}.business-switch-trigger{min-height:38px;border-radius:14px;border:1px solid rgb(255 255 255 / .58);background:linear-gradient(145deg,#ffffff3d,#ffffff1a);color:var(--hero-text);display:inline-flex;align-items:center;gap:8px;max-width:100%;padding:6px 12px;cursor:pointer;font-weight:700;box-shadow:0 6px 16px #00000029;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.business-switch-trigger span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.business-switch-trigger:disabled{opacity:.65;cursor:not-allowed}.business-switch-menu{position:absolute;top:calc(100% + 8px);left:0;width:max(220px,min(100%,320px));max-height:240px;overflow-y:auto;border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:0 10px 24px rgb(var(--primary-rgb) / .24);z-index:20;padding:6px}.business-switch-item{width:100%;border-radius:10px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;color:var(--text)}.business-switch-item:hover:not(:disabled),.business-switch-item.active{background:var(--primary-soft);color:var(--primary-ink)}.business-switch-item.active{font-weight:700;border:1px solid rgb(var(--primary-rgb) / .25)}.mobile-hero-logout{width:34px;height:34px;border-radius:999px;border:1px solid rgb(255 255 255 / .35);color:var(--hero-text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.mobile-profile{display:flex;align-items:center;gap:12px}.mobile-avatar{width:56px;height:56px;border-radius:999px;border:3px solid rgb(255 255 255 / .7);background:linear-gradient(145deg,var(--primary-soft),var(--surface-soft));color:var(--primary-ink);font-weight:800;display:inline-flex;align-items:center;justify-content:center}.mobile-user-name{font-size:18px;margin-bottom:2px;line-height:1.15}.mobile-user-email{font-size:13px;opacity:.96}.mobile-bottom-nav{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:100vw;height:calc(64px + env(safe-area-inset-bottom));padding:6px 4px calc(6px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--surface);display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:2px;z-index:10;box-sizing:border-box}.mobile-tab{text-decoration:none;color:var(--muted);border-radius:12px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:10px;font-weight:700;min-width:0;padding:4px 2px}.mobile-tab span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.1;text-align:center}.mobile-tab.active{background:var(--primary-soft);color:var(--primary)}.sidebar{display:none}.sidebar-header{display:flex;flex-direction:column;gap:8px}.sidebar-header h2{font-size:18px}.sidebar-header p{font-size:13px;color:var(--muted)}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.nav-item{text-decoration:none;display:inline-flex;align-items:center;gap:10px;border-radius:10px;padding:10px 12px;color:var(--muted)}.nav-item.active{background:var(--primary-soft);color:var(--primary-ink)}.sidebar-spacer{flex:1}.page-header{margin-bottom:18px}.page-header h1{font-size:24px;margin-bottom:5px}.page-header p{color:var(--muted);font-size:15px}.catalog-folder-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.catalog-folder-chip{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:8px 14px;font-size:14px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.catalog-folder-chip:hover{border-color:var(--primary);background:var(--surface-soft)}.catalog-folder-chip.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-ink);font-weight:600}.mobile-page-header h1{font-size:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:20px;margin-bottom:16px;box-shadow:0 2px 8px #0000000f}.card-header{margin-bottom:12px}.card-title{font-size:18px;margin-bottom:2px}.card-subtitle{color:var(--muted);font-size:15px}.form-stack{display:flex;flex-direction:column;gap:14px}.form-row{display:grid;grid-template-columns:1fr;gap:14px}.form-row.full{grid-template-columns:1fr}.grid{display:grid;grid-template-columns:1fr;gap:12px}.grid.cols-2,.grid.cols-1{grid-template-columns:1fr}.mobile-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 10px;margin-bottom:18px}.mobile-action-item{border-radius:16px;border:1px solid transparent;background:transparent;color:var(--primary-ink);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;padding:8px 4px}.mobile-action-icon{width:74px;height:74px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--primary);background:radial-gradient(circle at 30% 30%,var(--surface-soft) 0%,var(--primary-soft) 70%,var(--primary-soft) 100%);border:1px solid var(--primary-soft);box-shadow:inset 0 0 0 8px rgb(var(--primary-rgb) / .08)}.mobile-action-label{text-align:center;font-size:15px;font-weight:800;color:var(--primary-ink)}.dashboard-details{margin-top:2px}.dashboard-shortcuts{display:flex;flex-direction:column;gap:10px}.product-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s ease}.product-card:hover{border-color:var(--primary-soft)}.product-card--interactive{cursor:pointer}.product-card--interactive:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.dashboard-product-grid{margin-top:12px}.product-name{font-size:17px;font-weight:700}.product-type{display:inline-flex;align-items:center;border-radius:999px;background:var(--primary-soft);color:var(--primary-ink);font-size:12px;font-weight:700;padding:4px 10px;margin-top:6px}.product-description{color:var(--muted);font-size:13px}.product-price{font-size:20px;font-weight:800;color:var(--primary)}.orders-desktop-table{display:none}.orders-mobile-list{display:flex;flex-direction:column;gap:10px}.order-mobile-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:8px}.order-mobile-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid var(--border);padding:10px 12px;text-align:left;font-size:14px}.table th{font-weight:700;color:var(--primary-ink)}.table tr:last-child td{border-bottom:none}.calendar-event-row{padding-bottom:12px;border-bottom:1px solid var(--border)}.calendar-event-row:last-child{border-bottom:none;padding-bottom:0}.calendar-event-title{font-weight:700;margin-bottom:4px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.badge-pending{background:#fff3d8;color:var(--warning)}.badge-confirmed{background:#ddf5e9;color:var(--success)}.badge-cancelled{background:#ffe0e6;color:var(--danger)}.badge-refunded{background:var(--primary-soft);color:var(--primary-ink)}.badge-muted{background:#f4f4f5;color:#71717a}.alert{border-radius:12px;padding:10px 12px;margin-bottom:12px;font-size:14px}.alert-error{border:1px solid #f7bec7;background:#ffebef;color:#be3248}.alert-success{border:1px solid #bde5cf;background:#e8f8ef;color:#177d4e}.loading,.empty-state{display:flex;align-items:center;justify-content:center;text-align:center;padding:32px 18px;color:var(--muted)}.loading-stack{flex-direction:column;gap:12px}.workspace-select-title{margin-bottom:4px}.workspace-select-subtitle{margin-bottom:16px}.workspace-select-list{display:flex;flex-direction:column;gap:10px}.workspace-logout{margin-top:16px}@media(min-width:700px)and (max-width:1023px){.portal-shell,.mobile-bottom-nav{width:100%}.mobile-action-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.portal-shell{width:100%;max-width:none;margin:0;display:grid;grid-template-columns:250px 1fr;box-shadow:none;border:none}.sidebar{display:flex;flex-direction:column;padding:24px 16px;gap:20px;border-right:1px solid var(--border);background:var(--surface-soft)}.business-switcher-desktop .business-switch-trigger{border-color:rgb(var(--primary-rgb) / .3);background:linear-gradient(145deg,var(--surface) 0%,var(--primary-soft) 100%);color:var(--primary-ink);box-shadow:0 6px 14px rgb(var(--primary-rgb) / .18)}.business-switcher-desktop .business-switch-menu{width:min(100%,280px)}.mobile-hero,.mobile-bottom-nav{display:none}.content{padding:28px}.grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.orders-desktop-table{display:block}.orders-mobile-list{display:none}}
