:root{--color-primary: #E8743B;--color-primary-hover: #D4682F;--color-primary-light: #FFF1EB;--color-secondary: #78716C;--color-neutral-50: #FAF8F5;--color-neutral-100: #F5F0EB;--color-neutral-200: #E7E5E4;--color-neutral-300: #D6D3D1;--color-neutral-400: #A8A29E;--color-neutral-500: #78716C;--color-neutral-600: #57534E;--color-neutral-700: #44403C;--color-neutral-800: #292524;--color-neutral-900: #1C1917;--color-success: #16A34A;--color-success-light: #F0FDF4;--color-warning: #EA580C;--color-warning-light: #FFF7ED;--color-error: #DC2626;--color-error-light: #FEE2E2;--color-info: #3B82F6;--color-info-light: #EFF6FF;--color-pink: #DB2777;--color-pink-light: #FDF2F8;--bg-app: #FAF8F5;--bg-card: #FFFFFF;--bg-sidebar: #1C1917;--bg-sidebar-hover: #292524;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--text-xs: 12px;--text-sm: 13px;--text-base: 14px;--text-lg: 16px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 32px;--font-family: "Noto Sans SC", -apple-system, BlinkMacSystemFont, sans-serif;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-black: 900;--line-height-normal: 1.5;--line-height-tight: 1.25;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--radius-2xl: 14px;--radius-full: 50%;--shadow-sm: 0 1px 3px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--border-color: #E7E5E4;--border-width: 1px;--transition-fast: .12s ease;--transition-normal: .2s ease;--z-dropdown: 10;--z-sticky: 50;--z-fixed: 100;--z-modal-backdrop: 60;--z-modal: 70;--z-toast: 80;--bp-mobile: 640px;--bp-tablet: 768px;--bp-desktop: 1024px;--bp-wide: 1280px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-neutral-900);background-color:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}button{font-family:var(--font-family);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font-family);outline:none}img{max-width:100%;height:auto;display:block}.app-layout{min-height:100vh;display:flex;flex-direction:column}@media (min-width: 768px){.app-layout{flex-direction:row}.app-sidebar{width:220px;min-width:220px;background:var(--bg-sidebar);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow-y:auto}.app-sidebar::-webkit-scrollbar{width:0}.app-main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:100vh}}@media (max-width: 767px){.app-sidebar{display:none}.app-main{flex:1;display:flex;flex-direction:column;min-height:100vh;padding-bottom:80px}}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.font-black{font-weight:var(--font-weight-black)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .2s ease}.animate-slide-up{animation:slideUp .3s ease}.sidebar-brand{padding:var(--space-5) var(--space-4);display:flex;align-items:center;gap:var(--space-2);border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-brand-icon{width:34px;height:34px;border-radius:var(--radius-lg);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-size:var(--text-lg)}.sidebar-brand-text{font-size:var(--text-base);font-weight:var(--font-weight-bold);color:#f5f5f4;letter-spacing:-.3px}.sidebar-nav{padding:var(--space-3) var(--space-2);flex:1}.sidebar-section-title{font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:#ffffff40;padding:var(--space-3) var(--space-2) var(--space-1);font-weight:var(--font-weight-semibold)}.sidebar-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);border-radius:var(--radius-md);font-size:var(--text-sm);color:#ffffff80;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.sidebar-item:hover{background:var(--bg-sidebar-hover);color:#fffc}.sidebar-item.active{background:var(--color-primary);color:#fff;font-weight:var(--font-weight-semibold)}.sidebar-item i{width:18px;text-align:center;font-size:var(--text-sm)}.sidebar-item .item-count{margin-left:auto;font-size:var(--text-xs);opacity:.5}.sidebar-user{padding:var(--space-3) var(--space-4);border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:var(--space-2)}.sidebar-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--text-sm);color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:#fffc}.sidebar-user-email{font-size:10px;color:#ffffff4d;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-toolbar{height:52px;background:var(--bg-card);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 var(--space-6);gap:var(--space-3);flex-shrink:0}@media (max-width: 767px){.app-toolbar{display:none}}.app-breadcrumb{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm)}.app-breadcrumb a{color:var(--color-secondary);text-decoration:none;transition:color var(--transition-fast)}.app-breadcrumb a:hover{color:var(--color-primary)}.app-breadcrumb .sep{color:var(--border-color);font-size:10px}.app-breadcrumb .current{color:var(--color-neutral-900);font-weight:var(--font-weight-semibold)}.toolbar-spacer{flex:1}.toolbar-search{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-app);border:1.5px solid var(--border-color);border-radius:var(--radius-md);padding:7px var(--space-3);width:260px;font-size:var(--text-sm);color:var(--color-secondary);cursor:pointer;transition:border-color var(--transition-fast)}.toolbar-search:hover{border-color:var(--color-primary)}.toolbar-search i{font-size:var(--text-sm)}.page-header{margin-bottom:var(--space-6)}.page-header h2{font-size:var(--text-2xl);font-weight:var(--font-weight-black);color:var(--color-neutral-900);letter-spacing:-.5px}.page-header p{font-size:var(--text-sm);color:var(--color-secondary);margin-top:var(--space-1)}@media (max-width: 767px){.page-header h2{font-size:var(--text-2xl)}}.app-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-4);border:1px solid var(--border-color);cursor:pointer;transition:all .15s ease;position:relative}.app-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #e8743b14;transform:translateY(-1px)}.app-card .card-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-3);font-size:var(--text-lg)}.app-card .card-title{font-size:var(--text-base);font-weight:var(--font-weight-bold);color:var(--color-neutral-900)}.app-card .card-sub{font-size:var(--text-sm);color:var(--color-secondary);margin-top:var(--space-1)}.app-card .card-arrow{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);color:var(--border-color);font-size:var(--text-sm)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-3)}@media (min-width: 768px){.card-grid-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 767px){.card-grid{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);cursor:pointer;border:none;font-family:var(--font-family);transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-outline{background:var(--bg-card);color:var(--color-neutral-900);border:1px solid var(--border-color)}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-ghost{background:transparent;color:var(--color-secondary)}.btn-ghost:hover{background:var(--bg-app);color:var(--color-neutral-900)}.btn-danger{background:var(--color-error-light);color:var(--color-error)}.btn-danger:hover{background:#fecaca}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-lg)}.btn-block{width:100%}.form-group{margin-bottom:var(--space-4)}.form-label{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-secondary);margin-bottom:var(--space-1);display:block}.form-input{width:100%;padding:11px var(--space-3);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-base);background:var(--bg-card);color:var(--color-neutral-900);font-family:var(--font-family);outline:none;transition:border-color var(--transition-fast)}.form-input:focus{border-color:var(--color-primary)}.form-input::placeholder{color:#b8b2ac}.form-input:disabled{background:var(--bg-app);cursor:not-allowed}.form-select{width:100%;padding:11px var(--space-3);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-card);color:var(--color-neutral-900);font-family:var(--font-family);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%2378716C' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;transition:border-color var(--transition-fast)}.form-select:focus{border-color:var(--color-primary)}@media (max-width: 767px){.form-input,.form-select{padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-lg)}}.app-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border-color)}.app-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:11px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;color:var(--color-secondary);background:var(--bg-app);border-bottom:1px solid var(--border-color)}.app-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-neutral-900);border-bottom:1px solid var(--border-color)}.app-table tr:last-child td{border-bottom:none}.app-table tr:hover td{background:#e8743b05}@media (max-width: 767px){.app-table{display:none}}.table-thumb{width:40px;height:40px;border-radius:var(--radius-md);object-fit:cover;background:var(--border-color)}.table-name-cell{display:flex;align-items:center;gap:var(--space-2)}.table-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:var(--font-weight-semibold)}.table-actions{display:flex;gap:var(--space-1)}.table-action-btn{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--color-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast)}.table-action-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.table-action-btn.danger:hover{border-color:var(--color-error);color:var(--color-error)}.filter-bar{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);overflow-x:auto;padding-bottom:var(--space-1)}.filter-bar::-webkit-scrollbar{display:none}.chip{padding:6px 14px;border-radius:20px;font-size:var(--text-sm);font-weight:var(--font-weight-medium);background:var(--bg-card);border:1px solid var(--border-color);color:var(--color-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.app-tab-bar{position:fixed;bottom:0;left:0;right:0;height:80px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border-color);display:flex;align-items:flex-start;padding-top:var(--space-2);z-index:var(--z-sticky)}@media (min-width: 768px){.app-tab-bar{display:none}}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--color-secondary);cursor:pointer;text-decoration:none}.tab-item i{font-size:var(--text-xl)}.tab-item.active{color:var(--color-primary)}.tab-item.add-btn i{font-size:28px;color:var(--color-primary)}.fab{position:fixed;bottom:96px;right:var(--space-5);width:52px;height:52px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 16px #e8743b66;z-index:var(--z-fixed);cursor:pointer;border:none;transition:all var(--transition-fast)}.fab:hover{background:var(--color-primary-hover);transform:scale(1.05)}@media (min-width: 768px){.fab{display:none}}.fab-menu{position:fixed;bottom:156px;right:var(--space-5);z-index:var(--z-fixed);display:flex;flex-direction:column;gap:var(--space-2);align-items:flex-end}.fab-menu-item{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-neutral-900);box-shadow:var(--shadow-md);white-space:nowrap;cursor:pointer}.fab-menu-item i{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm)}.fab-menu-item.add-current i{background:var(--color-primary-light);color:var(--color-primary)}.fab-menu-item.add-item i{background:var(--color-success-light);color:var(--color-success)}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:var(--z-modal-backdrop)}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;padding:var(--space-5);z-index:var(--z-modal);max-height:70vh;overflow-y:auto;animation:slideUp .3s ease}.bottom-sheet .sheet-handle{width:36px;height:4px;background:var(--border-color);border-radius:2px;margin:0 auto var(--space-4)}.bottom-sheet h3{font-size:17px;font-weight:var(--font-weight-bold);margin-bottom:var(--space-4);color:var(--color-neutral-900)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop)}.modal-box{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-6);width:320px;max-width:90vw;text-align:center;animation:fadeIn .2s ease}.modal-box h4{font-size:var(--text-lg);font-weight:var(--font-weight-bold);color:var(--color-neutral-900);margin-bottom:var(--space-2)}.modal-box p{font-size:var(--text-sm);color:var(--color-secondary);margin-bottom:var(--space-5);line-height:1.5}.modal-btns{display:flex;gap:var(--space-2)}.modal-btns .btn{flex:1}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2)}.toast{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-md);font-size:var(--text-sm);color:var(--color-neutral-900);animation:fadeIn .2s ease;display:flex;align-items:center;gap:var(--space-2)}.toast.success{border-left:3px solid var(--color-success)}.toast.error{border-left:3px solid var(--color-error)}.toast.warning{border-left:3px solid var(--color-warning)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-5)}@media (max-width: 767px){.photo-grid{grid-template-columns:repeat(2,1fr)}}.photo-grid img{width:100%;height:140px;object-fit:cover;border-radius:var(--radius-lg);background:var(--border-color);cursor:pointer}@media (max-width: 767px){.photo-grid img{height:120px}}.photo-add{height:140px;border-radius:var(--radius-lg);background:var(--bg-card);border:1.5px dashed var(--border-color);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-1);color:var(--color-secondary);font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition-fast)}.photo-add:hover{border-color:var(--color-primary)}.photo-add i{font-size:var(--text-xl)}.prop-list{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-color);overflow:hidden}.prop-row{display:flex;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);font-size:var(--text-sm)}.prop-row:last-child{border-bottom:none}.prop-label{width:80px;color:var(--color-secondary);flex-shrink:0}.prop-value{color:var(--color-neutral-900);font-weight:var(--font-weight-medium)}.prop-value.accent{color:var(--color-primary)}.timeline-item{display:flex;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);border-bottom:1px solid var(--border-color)}.timeline-item:last-child{border-bottom:none}.timeline-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-primary);margin-top:5px;flex-shrink:0}.timeline-text{color:var(--color-neutral-900)}.timeline-time{color:var(--color-secondary);font-size:11px;margin-top:2px}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-1);margin-top:var(--space-6)}.page-btn{width:34px;height:34px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-card);color:var(--color-neutral-900);font-size:var(--text-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:var(--font-family);transition:all var(--transition-fast)}.page-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.page-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.invite-box{background:var(--color-primary-light);border:1.5px dashed var(--color-primary);border-radius:var(--radius-xl);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-6);margin-bottom:var(--space-6)}@media (max-width: 767px){.invite-box{flex-direction:column;text-align:center}}.invite-code-area{text-align:center}.invite-label{font-size:11px;color:var(--color-primary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:1px}.invite-code{font-size:32px;font-weight:var(--font-weight-black);letter-spacing:6px;color:var(--color-primary);margin:var(--space-1) 0}@media (max-width: 767px){.invite-code{font-size:28px;letter-spacing:4px}}.invite-hint{font-size:11px;color:var(--color-secondary)}.invite-actions{display:flex;gap:var(--space-2)}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}@media (max-width: 767px){.stat-row{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}}.stat-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);border:1px solid var(--border-color)}.stat-card .stat-icon{width:36px;height:36px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-3);font-size:var(--text-lg)}.stat-card .stat-num{font-size:var(--text-3xl);font-weight:var(--font-weight-black);color:var(--color-neutral-900);letter-spacing:-1px}@media (max-width: 767px){.stat-card .stat-num{font-size:28px}}.stat-card .stat-label{font-size:var(--text-sm);color:var(--color-secondary);margin-top:2px}.settings-layout{display:grid;grid-template-columns:200px 1fr;gap:var(--space-6)}@media (max-width: 767px){.settings-layout{grid-template-columns:1fr}}.settings-nav{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-color);padding:var(--space-2);height:fit-content}@media (max-width: 767px){.settings-nav{display:none}}.settings-nav-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-secondary);cursor:pointer;transition:all var(--transition-fast)}.settings-nav-item:hover{background:var(--bg-app);color:var(--color-neutral-900)}.settings-nav-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.settings-nav-item i{width:var(--text-lg);text-align:center;font-size:var(--text-sm)}.settings-section{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-color);padding:var(--space-5);margin-bottom:var(--space-4)}.settings-section h3{font-size:15px;font-weight:var(--font-weight-bold);color:var(--color-neutral-900);margin-bottom:var(--space-4)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--border-color)}.setting-row:last-child{border-bottom:none}.setting-label{font-size:var(--text-sm);color:var(--color-neutral-900)}.setting-desc{font-size:11px;color:var(--color-secondary);margin-top:2px}.toggle{width:40px;height:24px;border-radius:12px;background:var(--border-color);position:relative;cursor:pointer;transition:background .2s}.toggle.on{background:var(--color-primary)}.toggle:after{content:"";position:absolute;width:20px;height:20px;border-radius:var(--radius-full);background:#fff;top:2px;left:2px;transition:.2s;box-shadow:0 1px 3px #00000026}.toggle.on:after{left:18px}.empty-state{text-align:center;padding:var(--space-10) var(--space-5)}.empty-state i{font-size:48px;color:var(--border-color);margin-bottom:var(--space-3)}.empty-state p{font-size:var(--text-base);color:var(--color-secondary)}.empty-state .empty-hint{font-size:var(--text-sm);color:var(--color-neutral-300);margin-top:var(--space-1)}.skeleton{background:linear-gradient(90deg,var(--border-color) 25%,#F0EDEA 50%,var(--border-color) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-card{height:120px;border-radius:var(--radius-xl)}.skeleton-text{height:16px;margin-bottom:var(--space-2)}.skeleton-text.short{width:60%}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:var(--font-weight-semibold)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-error{background:var(--color-error-light);color:var(--color-error)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-neutral{background:#f3f4f6;color:var(--color-secondary)}.badge-pink{background:var(--color-pink-light);color:var(--color-pink)}.search-bar{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-4)}.search-bar i{color:var(--color-secondary);font-size:var(--text-base)}.search-bar input{flex:1;border:none;background:none;font-size:var(--text-base);color:var(--color-neutral-900);outline:none}.search-bar input::placeholder{color:#b8b2ac}.detail-layout{display:grid;grid-template-columns:1fr 340px;gap:var(--space-6)}@media (max-width: 767px){.detail-layout{grid-template-columns:1fr}}.auth-layout{display:flex;height:100vh}@media (max-width: 767px){.auth-layout{flex-direction:column;height:auto;min-height:100vh}}.auth-left{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-10)}@media (max-width: 767px){.auth-left{padding:var(--space-10) var(--space-6);align-items:flex-start;padding-top:60px}}.auth-right{width:400px;background:var(--color-primary);display:flex;align-items:center;justify-content:center;padding:var(--space-10);position:relative;overflow:hidden}@media (max-width: 767px){.auth-right{display:none}}.auth-right-content{position:relative;z-index:1;text-align:center;color:#fff}.auth-right-content h3{font-size:var(--text-2xl);font-weight:var(--font-weight-black);margin-bottom:var(--space-3)}.auth-right-content p{font-size:var(--text-base);opacity:.8;line-height:1.7}.auth-form{width:340px}@media (max-width: 767px){.auth-form{width:100%}}.auth-form h2{font-size:var(--text-2xl);font-weight:var(--font-weight-black);color:var(--color-neutral-900);margin-bottom:var(--space-1)}.auth-form .subtitle{font-size:var(--text-sm);color:var(--color-secondary);margin-bottom:var(--space-8)}.app-scroll{flex:1;overflow-y:auto;padding:var(--space-6)}.app-scroll::-webkit-scrollbar{width:6px}.app-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}@media (max-width: 767px){.app-scroll{padding:0 var(--space-5) var(--space-5)}}.breadcrumb{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);color:var(--color-secondary);background:var(--bg-app);border-bottom:1px solid var(--border-color)}.breadcrumb a{color:var(--color-primary);text-decoration:none}.breadcrumb .sep{opacity:.4}.breadcrumb .current{color:var(--color-neutral-900);font-weight:var(--font-weight-medium)}@media (min-width: 768px){.breadcrumb{display:none}}.mobile-header{padding:var(--space-2) var(--space-5) var(--space-4);background:var(--bg-app);position:sticky;top:0;z-index:var(--z-dropdown)}@media (min-width: 768px){.mobile-header{display:none}}.mobile-header h2{font-size:var(--text-2xl);font-weight:var(--font-weight-black);color:var(--color-neutral-900);letter-spacing:-.5px}.mobile-header p{font-size:var(--text-sm);color:var(--color-secondary);margin-top:2px}.highlight{background:#fef08a;padding:0 2px;border-radius:2px}
