@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";:root{--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--green-800:#166534;--green-900:#14532d;--green-light:#86efac;--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-200:#bfdbfe;--blue-700:#1d4ed8;--blue-800:#1e40af;--red-50:#fef2f2;--red-100:#fecaca;--red-700:#b91c1c;--red-800:#7f1d1d;--yellow-50:#fefce8;--yellow-100:#fef9c3;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-900:#111827;--radius-sm:8px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 32px #0000001f;--font:"DM Sans", system-ui, sans-serif;--font-mono:"Courier New", monospace}*,:before,:after{box-sizing:border-box}body{font-family:var(--font);background:var(--gray-50);color:var(--gray-900);margin:0}button,input,textarea{font-family:var(--font)}.login-page{min-height:100vh;display:flex}.login-left{background:linear-gradient(160deg,#1a3d1f 0%,#2e7d32 55%,#43a047 100%);flex-direction:column;flex:1;justify-content:center;padding:60px 56px;display:flex;position:relative;overflow:hidden}.login-left-decor{pointer-events:none;border:1px solid #ffffff1a;border-radius:50%;position:absolute}.login-logo{background:#ffffff26;border:1px solid #fff3;border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:32px;font-size:26px;display:flex}.login-hero-title{color:#fff;letter-spacing:-.5px;margin:0 0 16px;font-size:38px;font-weight:700;line-height:1.25}.login-hero-title span{color:var(--green-light)}.login-hero-sub{color:#ffffffb8;max-width:320px;margin:0 0 40px;font-size:15px;line-height:1.7}.login-features{flex-direction:column;gap:10px;display:flex}.login-pill{border-radius:var(--radius-full);color:#ffffffe6;background:#ffffff1f;border:1px solid #ffffff2e;align-items:center;gap:8px;padding:8px 16px;font-size:13px;display:inline-flex}.login-pill-dot{background:var(--green-light);border-radius:50%;flex-shrink:0;width:7px;height:7px}.login-right{background:#fff;flex-shrink:0;justify-content:center;align-items:center;width:480px;padding:40px 48px;display:flex}.login-form{width:100%;max-width:380px}.login-steps{align-items:center;gap:8px;margin-bottom:32px;display:flex}.login-step-dot{border-radius:var(--radius-full);background:var(--gray-200);height:8px;transition:all .3s}.login-step-dot.active{background:var(--green-700);width:24px}.login-step-dot.inactive{width:8px}.login-step-dot.done{background:var(--green-700);width:8px}.login-title{color:var(--gray-900);letter-spacing:-.3px;margin:0 0 4px;font-size:26px;font-weight:700}.login-subtitle{color:var(--gray-500);margin:0 0 28px;font-size:14px}.login-label{color:var(--gray-700);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.login-input-wrap{margin-bottom:16px;position:relative}.login-input-icon{pointer-events:none;font-size:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.login-input{border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);box-sizing:border-box;background:#fafafa;outline:none;width:100%;padding:13px 14px 13px 42px;font-size:15px;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--green-700);background:#fff;box-shadow:0 0 0 3px #15803d1f}.login-input.error{border-color:#f87171}.otp-row{gap:8px;margin-bottom:16px;display:flex}.otp-box{text-align:center;border:2px solid var(--gray-200);border-radius:var(--radius-lg);height:52px;color:var(--gray-900);background:#fafafa;outline:none;flex:1;min-width:0;font-size:20px;font-weight:700;transition:all .15s}.otp-box:focus{border-color:var(--green-700);background:#fff}.otp-box.filled{border-color:var(--green-light);background:var(--green-50)}.btn-primary{background:var(--green-700);color:#fff;border-radius:var(--radius-lg);cursor:pointer;border:none;width:100%;margin-top:4px;padding:14px;font-size:15px;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--green-800)}.btn-primary:disabled{background:var(--gray-300);color:var(--gray-400);cursor:not-allowed}.btn-ghost{cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:8px 0;font-size:13px;transition:color .15s;display:flex}.btn-ghost.green{color:var(--green-700);font-weight:600}.btn-ghost.green:hover{color:var(--green-800)}.btn-ghost.gray{color:var(--gray-500)}.btn-ghost.gray:hover{color:var(--gray-700)}.login-resend-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:16px;display:flex}.login-terms{color:var(--gray-400);text-align:center;margin-top:20px;font-size:12px;line-height:1.6}.alert{border-radius:var(--radius-md);align-items:flex-start;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.alert-error{background:var(--red-50);border:1px solid var(--red-100);color:var(--red-700)}.alert-success{background:var(--green-50);border:1px solid var(--green-200);color:var(--green-700)}.alert-icon{flex-shrink:0;margin-top:1px;font-size:16px}.app-nav{border-bottom:1px solid var(--gray-200);z-index:20;background:#fff;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.app-nav-brand{align-items:center;gap:10px;display:flex}.app-nav-logo{font-size:22px}.app-nav-title{color:var(--gray-900);font-size:14px;font-weight:700}.app-nav-phone{color:var(--gray-400);font-size:11px;font-family:var(--font-mono)}.btn-nav{border:1px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;color:var(--gray-700);background:#fff;padding:7px 16px;font-size:13px;transition:all .15s}.btn-nav:hover{background:var(--gray-50)}.btn-nav.danger{color:#ef4444}.btn-nav.danger:hover{background:var(--red-50);border-color:var(--red-100)}.btn-nav.primary{background:var(--green-700);color:#fff;border-color:var(--green-700);font-weight:600}.btn-nav.primary:hover{background:var(--green-800)}.dashboard-page{background:var(--gray-50);min-height:100vh}.dashboard-container{max-width:860px;margin:0 auto;padding:20px 16px 40px}.card{border:1px solid var(--gray-200);border-radius:var(--radius-xl);background:#fff;margin-bottom:16px;padding:20px}.section-title{margin-bottom:16px}.section-title-row{align-items:center;gap:10px;display:flex}.section-title-icon{border-radius:var(--radius-md);background:var(--green-50);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.section-title-text{color:var(--gray-900);margin:0;font-size:16px;font-weight:700}.section-title-sub{color:var(--gray-500);margin:6px 0 0 44px;font-size:12px}.toast{z-index:100;border-radius:var(--radius-lg);white-space:nowrap;align-items:center;gap:10px;padding:12px 20px;font-size:14px;line-height:1.5;animation:.2s toastIn;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000001f}.toast.success{color:#fff;background:#1a1a1a;border:none}.toast.error{color:#fff;background:#b91c1c;border:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.details-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px;display:grid}.field-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.field-input{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);box-sizing:border-box;width:100%;font-size:14px;font-family:var(--font);background:#fafafa;outline:none;padding:11px 12px;transition:border-color .15s,background .15s}.field-input:focus{border-color:var(--green-700);background:#fff}.field-textarea{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);box-sizing:border-box;resize:vertical;width:100%;font-size:14px;line-height:1.6;font-family:var(--font);background:#fafafa;outline:none;padding:11px 12px;transition:border-color .15s,background .15s}.field-textarea:focus{border-color:var(--green-700);background:#fff}.gender-row{gap:8px;display:flex}.gender-btn{border-radius:var(--radius-md);cursor:pointer;border:1.5px solid var(--gray-200);color:var(--gray-500);font-size:13px;font-weight:500;font-family:var(--font);background:#fafafa;flex:1;padding:10px 4px;transition:all .15s}.gender-btn:hover{border-color:var(--green-600);color:var(--green-700)}.gender-btn.selected{border-color:var(--green-700);background:var(--green-50);color:var(--green-700)}.btn-save{background:var(--green-700);color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;font-size:14px;font-weight:600;font-family:var(--font);border:none;margin-top:14px;padding:11px 20px;transition:background .15s}.btn-save:hover:not(:disabled){background:var(--green-800)}.btn-save:disabled{opacity:.7;cursor:not-allowed}.progress-dots{flex-wrap:wrap;align-items:center;gap:6px;margin:16px 0;display:flex}.progress-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;transition:all .2s;display:flex}.progress-dot.done{background:var(--green-700);color:#fff;border:2px solid var(--green-700)}.progress-dot.today{background:var(--blue-700);color:#fff;border:2px solid var(--blue-700);box-shadow:0 0 0 3px var(--blue-200), 0 0 0 5px #fff}.progress-dot.future{background:var(--gray-100);color:var(--gray-400);border:2px solid var(--gray-200)}.progress-label{color:var(--gray-500);margin-left:4px;font-size:13px}.entries-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;font-weight:600}.entry-card{border:1px solid var(--green-50);border-left:3px solid var(--green-600);border-radius:var(--radius-md);background:#fafafa;margin-bottom:8px;padding:10px 12px}.entry-card-header{justify-content:space-between;align-items:center;margin-bottom:3px;display:flex}.entry-day-label{color:var(--green-700);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.entry-date{color:var(--gray-400);font-size:11px}.entry-text{color:var(--gray-700);margin:0;font-size:13px;line-height:1.5}.divider{background:var(--gray-100);height:1px;margin:4px 0 16px}.entry-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-bottom:10px;display:flex}.entry-day-badge{color:var(--green-700);background:var(--green-50);border-radius:var(--radius-full);border:1px solid var(--green-200);padding:4px 12px;font-size:13px;font-weight:700}.entry-unlock-text{color:var(--gray-400);font-size:11px}.entry-textarea{border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);resize:vertical;box-sizing:border-box;width:100%;font-size:14px;line-height:1.6;font-family:var(--font);background:#fafafa;outline:none;padding:12px;transition:border-color .15s,background .15s}.entry-textarea:focus{border-color:var(--green-700);background:#fff}.entry-footer{justify-content:space-between;align-items:center;gap:8px;margin-top:8px;display:flex}.char-count{color:var(--gray-400);flex-shrink:0;font-size:12px}.char-count.warn{color:#ef4444}.btn-submit{border-radius:var(--radius-md);cursor:pointer;background:var(--green-700);color:#fff;white-space:nowrap;font-size:14px;font-weight:600;font-family:var(--font);border:none;padding:11px 20px;transition:background .15s}.btn-submit:hover:not(:disabled){background:var(--green-800)}.btn-submit:disabled{background:var(--gray-300);color:var(--gray-400);cursor:not-allowed}.state-card{border-radius:var(--radius-lg);text-align:center;padding:20px}.state-card.blue{background:var(--blue-50);border:1px solid var(--blue-100)}.state-card.green{background:var(--green-50);border:1px solid var(--green-200)}.state-card.red{background:var(--red-50);border:1px solid var(--red-100);text-align:left}.state-emoji{margin-bottom:10px;font-size:40px}.state-title{margin:0 0 6px;font-weight:700}.state-title.blue{color:var(--blue-800);font-size:16px}.state-title.green{color:var(--green-900);font-size:18px}.state-title.red{color:var(--red-700);font-size:15px}.state-text.blue{color:#3b82f6;margin:0;font-size:13px}.state-text.green{color:var(--gray-500);margin:0 0 4px;font-size:14px}.state-text.red{color:var(--red-800);margin:0;font-size:13px}.report-box{background:linear-gradient(135deg, var(--green-50), var(--green-100));border:1px solid var(--green-200);border-radius:var(--radius-lg);padding:16px}.report-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.report-title{color:var(--green-900);margin:0 0 4px;font-size:17px;font-weight:700}.report-date{color:#4ade80;margin:0;font-size:12px}.btn-download{background:var(--green-700);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;font-size:13px;font-weight:600;font-family:var(--font);border:none;align-items:center;gap:6px;padding:9px 16px;transition:background .15s;display:flex}.btn-download:hover{background:var(--green-800)}.btn-generate{background:var(--green-700);color:#fff;border-radius:var(--radius-lg);cursor:pointer;width:100%;font-size:15px;font-weight:600;font-family:var(--font);border:none;padding:13px 28px;transition:background .15s}.btn-generate:hover:not(:disabled){background:var(--green-800)}.btn-generate:disabled{background:var(--gray-300);color:var(--gray-400);cursor:not-allowed}.report-body{color:#1a2e1a;font-size:14px;line-height:1.75}.report-body .md-h2{color:var(--green-900);border-bottom:1px solid var(--green-200);margin:16px 0 6px;padding-bottom:4px;font-size:16px;font-weight:700}.report-body .md-h3{color:var(--green-800);margin:12px 0 4px;font-size:14px;font-weight:700}.report-body .md-h4{color:var(--green-700);margin:10px 0 3px;font-size:13px;font-weight:700}.report-body .md-ul{margin:6px 0 10px;padding-left:18px}.report-body .md-ul li{margin-bottom:5px}.report-body .md-p{margin:6px 0}.report-body strong{color:var(--green-700)}.spinner-wrap{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--green-700);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.admin-page{background:var(--gray-50);min-height:100vh}.admin-nav{border-bottom:1px solid var(--gray-200);z-index:30;background:#fff;justify-content:space-between;align-items:center;height:52px;padding:0 16px;display:flex;position:sticky;top:0}.admin-nav-left{align-items:center;gap:8px;display:flex}.admin-nav-logo{font-size:18px}.admin-nav-title{color:var(--gray-900);font-size:14px;font-weight:700}.admin-badge{background:var(--green-100);color:var(--green-700);border-radius:var(--radius-full);padding:2px 8px;font-size:11px;font-weight:600}.admin-nav-right{align-items:center;gap:6px;display:flex}.admin-container{max-width:1100px;margin:0 auto;padding:20px 12px}.admin-page-title{color:var(--gray-900);margin:0 0 4px;font-size:20px;font-weight:700}.admin-page-sub{color:var(--gray-500);margin:0;font-size:13px}.stat-cards{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.stat-card{border:1px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;flex:1;min-width:80px;padding:12px 16px}.stat-value{color:var(--gray-900);font-size:22px;font-weight:700}.stat-label{color:var(--gray-400);margin-top:2px;font-size:11px}.admin-search{border-radius:var(--radius-sm);border:1px solid var(--gray-200);box-sizing:border-box;width:100%;font-size:14px;font-family:var(--font);background:#fff;outline:none;margin-bottom:10px;padding:9px 14px}.admin-search:focus{border-color:var(--green-600)}.filter-row{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.filter-btn{border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;font-size:12px;font-family:var(--font);border:1px solid var(--gray-200);color:var(--gray-500);background:0 0;padding:6px 12px;font-weight:400;transition:all .15s}.filter-btn:hover{border-color:var(--green-600);color:var(--green-700)}.filter-btn.active{background:var(--green-700);color:#fff;border-color:var(--green-700);font-weight:600}.table-wrap{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;overflow:hidden}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;min-width:500px}.admin-table th{text-align:left;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;background:var(--gray-50);border-bottom:1px solid var(--gray-200);padding:10px 14px;font-size:11px;font-weight:700}.admin-table td{border-bottom:1px solid var(--gray-100);padding:12px 14px;font-size:13px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--gray-50)}.table-footer{border-top:1px solid var(--gray-100);color:var(--gray-400);padding:10px 14px;font-size:12px}.table-empty{text-align:center;color:var(--gray-400);padding:40px}.btn-view{border:1px solid var(--gray-300);cursor:pointer;color:var(--gray-700);white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--font);background:#fff;border-radius:7px;padding:6px 14px;transition:all .15s}.btn-view:hover{background:var(--green-50);border-color:var(--green-200);color:var(--green-700)}.status-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-badge-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.admin-progress{align-items:center;gap:3px;display:flex}.admin-progress-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .2s}.drawer-scrim{z-index:40;background:#00000059;animation:.18s fadeIn;position:fixed;inset:0}.drawer-panel{z-index:50;width:min(560px,100vw);box-shadow:var(--shadow-lg);background:#fff;animation:.22s cubic-bezier(.16,1,.3,1) slideIn;position:fixed;top:0;bottom:0;right:0;overflow-y:auto}.drawer-header{background:var(--gray-50);border-bottom:1px solid var(--gray-200);z-index:1;padding:16px 20px;position:sticky;top:0}.drawer-header-row{justify-content:space-between;align-items:flex-start;display:flex}.drawer-customer-label{color:var(--gray-500);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600}.drawer-phone{color:var(--gray-900);font-size:16px;font-weight:700;font-family:var(--font-mono);word-break:break-all}.btn-close{border:1px solid var(--gray-200);cursor:pointer;width:34px;height:34px;color:var(--gray-500);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:12px;font-size:18px;transition:background .15s;display:flex}.btn-close:hover{background:var(--gray-100)}.drawer-badges{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.drawer-started{color:var(--gray-500);align-items:center;gap:4px;font-size:12px;display:flex}.drawer-body{padding:0 20px 40px}.drawer-section{margin-top:22px}.detail-row{border-bottom:1px solid var(--gray-100);align-items:flex-start;gap:12px;padding:9px 0;display:flex}.detail-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;min-width:80px;padding-top:1px;font-size:12px;font-weight:500}.detail-value{color:var(--gray-900);flex:1;font-size:14px;line-height:1.5}.detail-box{border-radius:var(--radius-md);border:1px solid var(--gray-100);background:#fafafa;padding:4px 14px}.empty-state{text-align:center;color:var(--gray-400);padding:20px 0;font-size:13px}.empty-state-icon{margin-bottom:6px;font-size:28px}.drawer-entry-card{border:1px solid var(--green-50);border-left:3px solid var(--green-600);border-radius:var(--radius-sm);background:#fafafa;margin-bottom:8px;padding:10px 12px}.drawer-entry-header{justify-content:space-between;margin-bottom:4px;display:flex}.drawer-entry-day{color:var(--green-700);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:700}.drawer-entry-date{color:var(--gray-400);font-size:11px}.drawer-entry-text{color:var(--gray-700);margin:0;font-size:13px;line-height:1.6}.drawer-report-box{background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--radius-md);color:#1a2e1a;padding:14px 16px;font-size:14px;line-height:1.75}.drawer-report-date{color:var(--gray-400);margin-top:8px;font-size:11px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (width<=768px){.login-right{width:100%!important}.admin-container{padding:16px 12px}}@media (width<=680px){.login-left{display:none}.login-right{align-items:flex-start;width:100%;min-height:100vh;padding:48px 24px 40px}.app-nav{padding:0 14px}.app-nav-title{font-size:13px}}@media (width<=600px){.dashboard-container{padding:14px 10px 32px}.card{border-radius:var(--radius-lg);padding:16px}.details-grid{grid-template-columns:1fr}.section-title-sub{margin-top:8px;margin-left:0}.admin-page-title{font-size:17px}.stat-card{min-width:70px;padding:10px 12px}.stat-value{font-size:18px}}@media (width<=480px){.otp-box{height:46px;font-size:18px}.otp-row{gap:6px}.progress-dot{width:32px;height:32px;font-size:11px}.entry-footer{flex-direction:column;align-items:stretch}.btn-submit{text-align:center;width:100%;padding:13px}.char-count{text-align:right}}
