@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&family=Inter:wght@300;400;500;600&display=swap";:root{--sage-50: #f4f7f2;--sage-100: #e4ede0;--sage-200: #c8dbc1;--sage-300: #a3c098;--sage-400: #7aa36d;--sage-500: #5a8a4f;--sage-600: #476e3e;--sage-700: #385532;--sage-800: #2d4429;--sage-900: #1e2e1b;--cream-50: #fdfcfa;--cream-100: #faf6ef;--cream-200: #f4ebe0;--cream-300: #ead8c4;--cream-400: #d9be9e;--cream-500: #c49a72;--warm-white: #fdfcfa;--warm-100: #f7f3ee;--color-primary: var(--sage-500);--color-primary-light: var(--sage-100);--color-primary-dark: var(--sage-700);--color-bg: var(--cream-50);--color-surface: #ffffff;--color-surface-2: var(--warm-100);--color-border: #e8e2d9;--color-border-strong: #d0c8bc;--color-text: #2a2420;--color-text-muted: #7a7068;--color-text-light: #a89f94;--color-success: #5a8a4f;--color-success-bg: #e8f0e5;--color-warning: #b87333;--color-warning-bg: #fdf0e0;--color-danger: #c0392b;--color-danger-bg: #fdecea;--color-info: #2980b9;--color-info-bg: #e8f4fd;--chart-muscle: var(--sage-500);--chart-fat: #c0766a;--chart-visceral: #b07d10;--font-serif: "Playfair Display", Georgia, serif;--font-sans: "Inter", -apple-system, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(42,36,32,.06), 0 1px 2px rgba(42,36,32,.04);--shadow-md: 0 4px 12px rgba(42,36,32,.08), 0 2px 4px rgba(42,36,32,.04);--shadow-lg: 0 8px 24px rgba(42,36,32,.1), 0 4px 8px rgba(42,36,32,.06);--sidebar-width: 240px;--topbar-height: 64px;--content-max: 900px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-serif);font-weight:500;line-height:1.25;color:var(--color-text)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.2rem}h4,h5,h6{font-weight:600;line-height:1.35}h4{font-size:1rem}p{line-height:1.65;color:var(--color-text-muted)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column}.page-body{flex:1;padding:32px;max-width:var(--content-max);width:100%;margin:0 auto}.sidebar-logo{padding:20px 14px 18px;border-bottom:1px solid var(--color-border)}.logo-mark{font-family:var(--font-serif);font-size:1.4rem;font-weight:600;color:var(--color-primary);letter-spacing:.04em}.logo-sub{font-size:.7rem;color:var(--color-text-light);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}.sidebar-nav{flex:1;padding:16px 0}.nav-section-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-light);padding:16px 20px 6px}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:.875rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;border-radius:0;transition:all .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-link:hover{background:var(--color-primary-light);color:var(--color-primary-dark);text-decoration:none}.nav-link.active{background:var(--color-primary-light);color:var(--color-primary-dark);font-weight:600;border-right:3px solid var(--color-primary)}.nav-link-icon{font-size:1rem;width:20px;text-align:center}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--color-border)}.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:12px}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-name{font-size:.875rem;font-weight:500;color:var(--color-text)}.user-role{font-size:.75rem;color:var(--color-text-light)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.card-sm{padding:16px;border-radius:var(--radius-md)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.card-title{font-family:var(--font-serif);font-size:1.1rem;font-weight:500;color:var(--color-text)}.card-subtitle{font-size:.8rem;color:var(--color-text-light);margin-top:2px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.page-title{font-family:var(--font-serif);font-size:1.75rem;font-weight:500;color:var(--color-text);margin-bottom:4px}.page-subtitle{font-size:.875rem;color:var(--color-text-muted);margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;font-family:var(--font-sans);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn-secondary{background:var(--color-surface);color:var(--color-primary);border-color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light)}.btn-ghost{background:transparent;color:var(--color-text-muted);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-surface-2);color:var(--color-text)}.btn-danger{background:var(--color-danger-bg);color:var(--color-danger);border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#fbd5d2}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-full{width:100%}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--color-text);margin-bottom:6px;letter-spacing:.02em}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;font-family:var(--font-sans);font-size:.9rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5a8a4f1f}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-hint{font-size:.75rem;color:var(--color-text-light);margin-top:4px}.form-error{font-size:.75rem;color:var(--color-danger);margin-top:4px}.badge{display:inline-flex;align-items:center;padding:2px 10px;font-size:.7rem;font-weight:600;border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase}.badge-active{background:var(--color-success-bg);color:var(--color-success)}.badge-pending{background:var(--color-warning-bg);color:var(--color-warning)}.badge-expired,.badge-inactive{background:#f0ede8;color:var(--color-text-muted)}.badge-sage{background:var(--sage-100);color:var(--sage-700)}.badge-warm{background:var(--cream-200);color:#7a4f20}.score-ring{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;color:var(--color-primary-dark);background:var(--color-primary-light);border:2px solid var(--color-primary);flex-shrink:0}.score-ring.low{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.score-ring.mid{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.score-ring.high{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.score-label{font-size:.62rem;font-weight:500;color:var(--color-text-muted);text-align:center;line-height:1.2}.banner{padding:12px 16px;border-radius:var(--radius-md);font-size:.875rem;display:flex;align-items:center;gap:10px;margin-bottom:20px}.banner-warning{background:var(--color-warning-bg);border:1px solid #e8c07a;color:#7a4f10}.banner-danger{background:var(--color-danger-bg);border:1px solid #e8a0a0;color:#7a1010}.banner-info{background:var(--sage-50);border:1px solid var(--sage-200);color:var(--sage-800)}.banner-success{background:var(--color-success-bg);border:1px solid var(--sage-300);color:var(--sage-800)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}th{padding:10px 16px;text-align:left;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-light);background:var(--color-surface-2);border-bottom:1px solid var(--color-border)}td{padding:12px 16px;border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--sage-50)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a242073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--color-surface);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:520px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal-title{font-family:var(--font-serif);font-size:1.4rem;font-weight:500;color:var(--color-text);margin-bottom:6px}.modal-subtitle{font-size:.875rem;color:var(--color-text-muted);margin-bottom:24px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-border)}.auth-page{min-height:100vh;background:var(--cream-100);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-mark{width:64px;height:64px;background:var(--color-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:1.4rem;font-weight:600;color:#fff;margin:0 auto 16px}.auth-logo h1{font-size:1.4rem;margin-bottom:4px}.auth-logo p{font-size:.875rem;color:var(--color-text-light);margin:0}.auth-error{background:var(--color-danger-bg);border:1px solid #f5c0bc;color:var(--color-danger);border-radius:var(--radius-md);padding:10px 14px;font-size:.875rem;margin-bottom:16px}.auth-footer{text-align:center;font-size:.8rem;color:var(--color-text-light);margin-top:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;text-align:center;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{box-shadow:var(--shadow-md)}.stat-icon{font-size:1.5rem;margin-bottom:8px}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:4px}.stat-label{font-size:.75rem;color:var(--color-text-light);font-weight:500;letter-spacing:.04em;text-transform:uppercase}.exercise-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;margin-bottom:10px}.exercise-name{font-weight:600;font-size:.95rem;color:var(--color-text);margin-bottom:4px}.exercise-prescription{font-size:.8rem;color:var(--color-text-muted);margin-bottom:10px}.pb-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;padding:2px 8px;background:var(--sage-100);color:var(--sage-700);border-radius:var(--radius-full);margin-left:8px}.set-row{display:grid;grid-template-columns:32px 1fr 1fr auto;gap:8px;align-items:center;margin-bottom:6px}.set-num{font-size:.75rem;font-weight:600;color:var(--color-text-light);text-align:center}.set-input{padding:7px 10px;font-size:.875rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);width:100%;background:var(--color-surface);color:var(--color-text);text-align:center}.set-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #5a8a4f1a}.dsi-slider-group{margin-bottom:12px}.dsi-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.dsi-slider-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.dsi-slider-value{font-size:1.1rem;font-weight:700;color:var(--color-primary);min-width:28px;text-align:right}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.date-input-wrap{padding-left:12px!important}.date-input-wrap input{line-height:1;min-width:0}.date-input-wrap input::placeholder{color:var(--color-text-muted);opacity:.6}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:var(--sage-100);border-radius:var(--radius-full);outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;box-shadow:0 1px 4px #5a8a4f4d}input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}.symptom-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.symptom-chip{padding:6px 14px;font-size:.8rem;font-weight:500;border-radius:var(--radius-full);border:1.5px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all .15s}.symptom-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.symptom-chip.selected{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary-dark);font-weight:600}.heatmap-grid{display:flex;flex-direction:column;gap:6px}.heatmap-row{display:flex;align-items:center;gap:6px}.heatmap-label{font-size:.72rem;color:var(--color-text-muted);width:110px;flex-shrink:0;font-weight:500}.heatmap-cells{display:flex;gap:4px;flex-wrap:wrap}.heatmap-cell{width:22px;height:22px;border-radius:4px;background:var(--sage-50);border:1px solid var(--color-border);cursor:default;transition:transform .1s}.heatmap-cell:hover{transform:scale(1.2)}.heatmap-cell[data-level="1"]{background:var(--sage-100)}.heatmap-cell[data-level="2"]{background:var(--sage-200)}.heatmap-cell[data-level="3"]{background:var(--sage-300)}.heatmap-cell[data-level="4"]{background:var(--sage-400)}.heatmap-cell[data-level="5"]{background:var(--sage-500)}.plan-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:var(--radius-md);font-size:.875rem;margin-bottom:20px;gap:12px;flex-wrap:wrap}.plan-banner-week{font-weight:600;color:var(--color-text)}.plan-banner-days{font-size:.8rem;color:var(--color-text-muted)}.empty-state{text-align:center;padding:60px 24px;color:var(--color-text-muted)}.empty-icon{font-size:2.5rem;margin-bottom:12px}.empty-state h3{font-family:var(--font-serif);font-size:1.2rem;color:var(--color-text);margin-bottom:8px}.empty-state p{max-width:360px;margin:0 auto 20px}.loading-spinner{width:36px;height:36px;border:3px solid var(--sage-100);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin:60px auto}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.skeleton{background:linear-gradient(90deg,var(--sage-50) 25%,var(--sage-100) 50%,var(--sage-50) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-md)}@keyframes shimmer{to{background-position:-200% 0}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--color-text-muted)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.mobile-topbar{display:none;align-items:center;justify-content:space-between;padding:0 16px;height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:90;flex-shrink:0}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--radius-md)}.hamburger-btn:hover{background:var(--color-surface-2)}.hamburger-btn span{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a242066;z-index:99;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.ci-layout{display:flex;gap:20px;align-items:flex-start}.ci-left{width:240px;flex-shrink:0}.ci-right{flex:1;min-width:0}.ci-tab-layout{display:flex;gap:16px;align-items:flex-start}.ci-tab-nav{width:210px;flex-shrink:0}.ci-tab-detail{flex:1;min-width:0}.tabs-bar{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs-bar::-webkit-scrollbar{display:none}.tabs-bar button{white-space:nowrap;flex-shrink:0}.mobile-back-btn{display:none}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .25s;z-index:100}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-topbar{display:flex}.page-body{padding:16px 14px}.page-header{margin-bottom:16px;gap:10px}.page-title{font-size:1.25rem}.page-subtitle{font-size:.82rem}.card{padding:16px}.card-title{font-size:1rem}.card-header{gap:8px}.grid-2,.grid-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:14px 10px}.stat-value{font-size:1.6rem}.stat-icon{font-size:1.2rem;margin-bottom:6px}th{padding:8px 10px;font-size:.68rem}td{padding:10px;font-size:.82rem}.auth-card{padding:28px 20px}h1{font-size:1.35rem}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;max-width:100%;padding:24px 20px 28px;max-height:92vh}.modal-footer{flex-direction:column-reverse;gap:8px}.modal-footer .btn{width:100%;justify-content:center}.banner{font-size:.82rem;padding:10px 14px}.ci-layout{flex-direction:column;gap:0}.ci-left{width:100%}.ci-right{width:100%;margin-top:16px}.ci-tab-layout{flex-direction:column;gap:0}.ci-tab-nav{width:100%}.ci-tab-detail{width:100%;margin-top:12px}.ci-tab-nav-inner{flex-direction:row!important;overflow-x:auto!important;max-height:none!important;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-radius:var(--radius-md)!important;padding:6px!important;gap:6px!important}.ci-tab-nav-inner::-webkit-scrollbar{display:none}.ci-week-btn{flex-direction:column!important;min-width:80px!important;text-align:center!important;border-bottom:none!important;border-right:1.5px solid var(--color-border)!important;padding:8px 10px!important;border-radius:var(--radius-md)!important;border:1.5px solid var(--color-border)!important;align-items:center!important;gap:3px!important}.ci-layout.mobile-detail .ci-left{display:none}.ci-layout:not(.mobile-detail) .ci-right{display:none}.mobile-back-btn{display:flex}.tabs-bar{margin-bottom:16px}.toast-popup{left:12px!important;right:12px!important;bottom:16px!important;max-width:none!important;min-width:0!important}}@media (max-width: 480px){.cal-month-cell{min-height:68px!important;padding-top:10px!important;padding-bottom:8px!important}.cal-month-cell .cal-day-num{font-size:1rem!important}.cal-day-header{font-size:.8rem!important;padding:8px 0!important}.cal-week-cell{padding:12px 4px!important}}@media (max-width: 400px){.stats-grid{gap:8px}.stat-card{padding:12px 8px}.stat-value{font-size:1.4rem}.page-body,.card{padding:14px 12px}.home-tab-bar button{padding:6px 2px!important;font-size:.65rem!important}}
