@import"https://fonts.googleapis.com/css2?family=Jost:wght@300;400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #7B9A6A;--primary-dark: #5E7B50;--primary-light: #ECF2E8;--primary-muted: #A8BF9A;--bg: #F5F1EC;--surface: #FFFFFF;--surface-alt: #FAF8F5;--dark: #252E21;--dark-hover: #323D2D;--border: #E4DDD5;--border-light: #EDE8E2;--text: #252118;--text-muted: #8C8278;--text-light: #B0A89E;--success: #5A8F5A;--success-light: #EAF2EA;--warning: #B08040;--warning-light: #FBF3E4;--danger: #A04040;--danger-light: #F5EAEA;--radius: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 4px rgba(37,33,24,.06);--shadow: 0 2px 14px rgba(37,33,24,.09);--shadow-md: 0 6px 28px rgba(37,33,24,.12);--nav-h: 64px}html,body{height:100%}body{font-family:Jost,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(ellipse at 20% 10%,rgba(123,154,106,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 90%,rgba(123,154,106,.04) 0%,transparent 60%);pointer-events:none;z-index:0}#root{height:100%;position:relative;z-index:1}.portal-layout{display:flex;flex-direction:column;min-height:100%}.portal-topbar{position:sticky;top:0;z-index:50;background:var(--dark);height:56px;display:flex;align-items:center;padding:0 16px;gap:12px;box-shadow:0 2px 12px #0003}.portal-topbar-logo{height:32px;width:auto;object-fit:contain;opacity:.9}.portal-topbar-divider{width:1px;height:20px;background:#d6e0d033}.portal-topbar-subtitle{font-size:12px;font-weight:500;color:#d6e0d099;letter-spacing:.3px;flex:1}.portal-topbar-name{font-size:13px;font-weight:600;color:#d6e0d0d9}.portal-topbar-logout{background:#ffffff12;border:1px solid rgba(255,255,255,.1);color:#d6e0d0b3;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.portal-topbar-logout:hover{background:#ffffff1f}.portal-content{flex:1;padding:20px 16px calc(var(--nav-h) + 20px);max-width:480px;width:100%;margin:0 auto;animation:pageFadeIn .22s ease}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 12px #2521180f}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;padding:5px 4px;border:none;background:transparent;cursor:pointer;text-decoration:none;color:var(--text-light);font-size:10px;font-weight:600;letter-spacing:.2px;transition:color .2s;font-family:Jost,sans-serif}.bottom-nav-item.active{color:var(--primary-dark)}.bottom-nav-item.active svg{stroke:var(--primary-dark)}.bottom-nav-item svg{width:21px;height:21px;stroke-width:1.8;transition:stroke .2s}.nav-icon{width:48px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:14px;transition:background .2s}.bottom-nav-item.active .nav-icon{background:var(--primary-light)}.card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);margin-bottom:12px;overflow:hidden}.card-title{font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 22px;border-radius:var(--radius);font-size:15px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s,transform .1s;text-decoration:none;font-family:Jost,sans-serif;letter-spacing:.2px}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;width:100%;box-shadow:0 2px 12px #5e7b5059}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-dark) 0%,#3e5536 100%);box-shadow:0 4px 18px #5e7b506b}.btn-outline{background:transparent;color:var(--primary-dark);border:1.5px solid var(--primary);width:auto}.btn-ghost{background:transparent;color:var(--text-muted);padding:8px 12px;font-size:14px;width:auto}.btn-danger{background:var(--danger-light);color:var(--danger);width:auto}.btn-sm{padding:7px 16px;font-size:13px;border-radius:20px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.form-input{display:block;width:100%;min-width:0;max-width:100%;box-sizing:border-box;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:15px;background:var(--surface-alt);color:var(--text);transition:border-color .15s,background .15s;outline:none;font-family:Jost,sans-serif}.form-input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px #7b9a6a1f}input[type=date].form-input,select.form-input{font-size:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;letter-spacing:.2px}.badge-green{background:var(--success-light);color:var(--success)}.badge-orange{background:var(--warning-light);color:var(--warning)}.badge-sage{background:var(--primary-light);color:var(--primary-dark)}.badge-gray{background:var(--surface-alt);color:var(--text-muted);border:1px solid var(--border)}.text-muted{color:var(--text-muted)}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-center{text-align:center}.mt-4{margin-top:16px}.mt-8{margin-top:32px}.mb-4{margin-bottom:16px}.flex{display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}.spinner{width:22px;height:22px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner-sage{border-color:var(--primary-light);border-top-color:var(--primary)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}@keyframes bounce-right{0%,to{transform:translate(0)}50%{transform:translate(5px,5px)}}.login-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.login-hero{background:#252e21;padding:52px 36px 40px;display:flex;flex-direction:column;align-items:center;gap:28px;position:relative;overflow:hidden}.login-hero-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 38%,rgba(123,154,106,.13) 0%,transparent 68%);pointer-events:none}.login-hero-ring{position:absolute;border-radius:50%;border:1px solid rgba(123,154,106,.1);pointer-events:none}.login-hero-badge{display:flex;align-items:center;gap:8px;align-self:flex-start;position:relative;z-index:1}.login-hero-badge-dot{width:6px;height:6px;border-radius:50%;background:#7b9a6a}.login-hero-badge span{font-size:9.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#d6e0d073}.login-hero-logo{width:62%;max-width:240px;height:auto;object-fit:contain;opacity:.93;position:relative;z-index:1}.login-hero-footer{display:flex;align-items:center;gap:12px;width:100%;position:relative;z-index:1}.login-hero-line{flex:1;height:1px;background:#d6e0d014}.login-hero-tagline{font-size:9.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#d6e0d040}.login-box{background:var(--surface);border-radius:var(--radius-lg);padding:32px 28px;width:calc(100% - 40px);max-width:380px;margin:28px auto 40px;box-shadow:var(--shadow-md);border:1px solid var(--border-light)}.login-box h1{font-size:21px;font-weight:700;color:var(--text);margin-bottom:4px}.login-box .subtitle{font-size:13px;color:var(--text-muted);margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border-light)}.weight-chart{width:100%;height:140px;overflow:visible}.foto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.foto-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer}.foto-item img{width:100%;height:100%;object-fit:cover}.foto-item-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#252e2180;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.foto-item:hover .foto-item-overlay{opacity:1}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#141812f2;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.lightbox img{max-width:100%;max-height:80vh;border-radius:10px;object-fit:contain}.lightbox-close{position:absolute;top:16px;right:16px;background:#d6e0d026;border:none;color:#d6e0d0cc;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s}.lightbox-close:hover{background:#d6e0d040}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:28px 16px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--surface-alt)}.upload-area:hover,.upload-area.drag-over{border-color:var(--primary);background:var(--primary-light)}.stat-row{display:flex;align-items:center;gap:14px;padding:11px 0;border-bottom:1px solid var(--border-light)}.stat-row:last-child{border-bottom:none}.stat-icon-circle{width:38px;height:38px;border-radius:10px;background:var(--primary-light);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.stat-value{font-size:17px;font-weight:700;color:var(--text);line-height:1.2}.dose-item{padding:13px 0;border-bottom:1px solid var(--border-light)}.dose-item:last-child{border-bottom:none}.dose-date{font-size:11px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}.dose-name{font-weight:700;font-size:15px;color:var(--text)}.dose-detail{font-size:13px;color:var(--text-muted);margin-top:3px}.toast{position:fixed;bottom:calc(var(--nav-h) + 14px);left:50%;transform:translate(-50%);background:var(--dark);color:#d6e0d0f2;padding:10px 22px;border-radius:24px;font-size:13.5px;font-weight:600;z-index:300;animation:toastIn .25s ease;white-space:nowrap;letter-spacing:.2px}.toast.success{background:var(--success);color:#fff}.toast.error{background:var(--danger);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.section-title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:16px;letter-spacing:-.3px}.empty-state{text-align:center;padding:36px 16px;color:var(--text-muted)}.empty-state svg{width:44px;height:44px;stroke:var(--border);margin-bottom:12px}.empty-state p{font-size:14px}.apt-card{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--border-light)}.apt-card:last-child{border-bottom:none}.apt-card.status-scheduled .apt-date-box{background:#e8f0fb;color:#3b72c4}.apt-card.status-cancelled .apt-date-box{background:var(--warning-light);color:var(--warning)}.apt-date-box{background:var(--primary-light);color:var(--primary-dark);border-radius:10px;padding:7px 10px;text-align:center;min-width:48px;flex-shrink:0}.apt-date-day{font-size:20px;font-weight:800;line-height:1}.apt-date-mon{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.hero-card{background:linear-gradient(135deg,var(--dark) 0%,#3a4e33 100%);color:#fff;border-radius:var(--radius-lg);padding:20px;margin-bottom:12px;position:relative;overflow:hidden;box-shadow:0 4px 20px #252e2140}.hero-card:before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;background:radial-gradient(circle,rgba(123,154,106,.32) 0%,transparent 70%);pointer-events:none}.hero-card:after{content:"";position:absolute;bottom:-55px;left:-35px;width:180px;height:180px;background:radial-gradient(circle,rgba(214,224,208,.08) 0%,transparent 70%);pointer-events:none}.shortcut-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.shortcut-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px 14px;text-decoration:none;text-align:center;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .15s,border-color .2s;display:block}.shortcut-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--primary-muted)}.shortcut-card:active{transform:scale(.96);box-shadow:var(--shadow-sm)}.shortcut-icon{width:46px;height:46px;border-radius:14px;background:var(--primary-light);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;transition:background .2s,transform .15s}.shortcut-card:hover .shortcut-icon{background:#deecd8;transform:scale(1.06)}.shortcut-label{font-size:12.5px;font-weight:700;color:var(--text);letter-spacing:.1px}.apt-time{font-size:11.5px;color:var(--text-muted);font-weight:500;margin-top:2px}.hero-card>*{position:relative;z-index:1}.login-box h1{font-size:22px;font-weight:800;color:var(--text);margin-bottom:6px;letter-spacing:-.3px}.empty-state svg{width:52px;height:52px;stroke:var(--border);margin:0 auto 14px;display:block}.foto-item{transition:transform .15s}.foto-item:active{transform:scale(.97)}.upload-area{border-radius:var(--radius-lg)}.stat-icon-circle{transition:background .15s;border-radius:12px}.bottom-nav{padding-bottom:max(env(safe-area-inset-bottom),4px)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}
