@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600;700&display=swap');
:root{--bg:#f7f3ee;--green:#16613a;--green-light:#e8f5ee;--amber:#d97706;--amber-light:#fef3c7;--red:#dc2626;--red-light:#fee2e2;--blue:#1d4ed8;--blue-light:#dbeafe;--muted:#78716c;--border:#e7e0d8;--dark:#1c1917;--white:#ffffff}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--dark)}
.hidden{display:none!important}

/* NAV */
nav{background:white;border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.nav-logo{font-family:'DM Serif Display',serif;font-size:22px;color:var(--green);cursor:pointer;text-decoration:none}
.nav-links{display:flex;gap:16px;align-items:center}
.nav-links a{font-size:14px;color:var(--muted);text-decoration:none;cursor:pointer}
.nav-btn{background:var(--green);color:white;border:none;padding:8px 20px;border-radius:100px;font-size:14px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif}
.nav-btn.outline{background:transparent;color:var(--dark);border:1.5px solid var(--border)}

/* BUTTONS */
.btn-primary{background:var(--green);color:white;border:none;padding:14px 32px;border-radius:100px;font-size:16px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity 0.2s}
.btn-primary:hover{opacity:0.9}
.btn-secondary{background:white;color:var(--dark);border:1.5px solid var(--border);padding:14px 32px;border-radius:100px;font-size:16px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif}
.btn-small{padding:8px 20px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;border:none}
.btn-green{background:var(--green);color:white}
.btn-amber{background:var(--amber);color:white}

/* SECTIONS */
.section-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);text-align:center;margin-bottom:12px}
.section-title{font-family:'DM Serif Display',serif;font-size:36px;text-align:center;margin-bottom:48px}

/* BADGES */
.badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:100px;flex-shrink:0}
.badge-urgent{background:var(--red-light);color:var(--red)}
.badge-important{background:var(--amber-light);color:var(--amber)}
.badge-optional{background:var(--blue-light);color:var(--blue)}

/* CARDS */
.card{background:white;border-radius:16px;border:1.5px solid var(--border);padding:20px}

/* CHECKLIST ITEMS */
.cl-item{background:white;border-radius:14px;padding:16px;margin-bottom:10px;display:flex;gap:14px;align-items:flex-start;border:1.5px solid var(--border);cursor:pointer;transition:all 0.15s}
.cl-item:hover{border-color:var(--green);transform:translateY(-1px);box-shadow:0 4px 12px rgba(22,97,58,0.08)}
.cl-item.done{opacity:0.6}
.cl-item.locked{cursor:default;opacity:0.5}
.cl-item.locked:hover{border-color:var(--border);transform:none;box-shadow:none}
.cl-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:white;margin-top:2px;transition:all 0.2s}
.cl-check.checked{background:var(--green);border-color:var(--green)}
.cl-check.locked-icon{background:#f0ece6;border-color:var(--border)}
.cl-title{font-size:15px;font-weight:600;margin-bottom:3px;line-height:1.4}
.cl-sub{font-size:13px;color:var(--muted);line-height:1.5}
.stage-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin:16px 0 8px}

/* PROGRESS */
.progress-wrap{background:white;border-radius:14px;padding:16px;margin-bottom:16px;border:1.5px solid var(--border)}
.progress-top{display:flex;justify-content:space-between;font-size:13px;font-weight:600;margin-bottom:8px}
.progress-top span:last-child{color:var(--green)}
.progress-bg{height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width 0.5s}

/* LOCKED BANNER */
.locked-banner{background:linear-gradient(135deg,var(--green),#0d4a2c);border-radius:16px;padding:24px;text-align:center;color:white;margin-top:16px}
.locked-banner h3{font-family:'DM Serif Display',serif;font-size:22px;margin-bottom:8px}
.locked-banner p{font-size:13px;color:rgba(255,255,255,0.75);margin-bottom:16px;line-height:1.6}
.locked-btn{background:white;color:var(--green);border:none;padding:10px 24px;border-radius:100px;font-size:14px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif}

/* STEP CARDS */
.step-card{background:white;border-radius:14px;margin-bottom:10px;border:1.5px solid var(--border);overflow:hidden}
.step-header{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;user-select:none}
.step-header:hover{background:#fafaf9}
.step-num{width:28px;height:28px;background:var(--green);color:white;border-radius:50%;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.step-title-text{flex:1;font-size:14px;font-weight:600;line-height:1.4}
.step-arrow{font-size:20px;color:var(--muted);transition:transform 0.2s}
.step-arrow.open{transform:rotate(90deg)}
.step-body{display:none;padding:0 16px 16px;border-top:1px solid var(--border)}
.step-body.open{display:block}
.step-section-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:12px 0 8px}
.step-docs{background:#f9f8f7;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:6px}
.step-doc{font-size:13px;line-height:1.6}
.step-process{display:flex;flex-direction:column;gap:6px}
.step-process-item{display:flex;gap:10px;align-items:flex-start}
.step-process-num{width:20px;height:20px;background:var(--green-light);color:var(--green);border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.step-process-text{font-size:13px;line-height:1.6}
.step-tip{background:var(--amber-light);border-radius:10px;padding:12px;margin-top:12px;display:flex;gap:10px;align-items:flex-start}
.step-tip-label{font-size:11px;font-weight:700;color:var(--amber);margin-bottom:4px}
.step-tip-text{font-size:13px;color:#78350f;line-height:1.6}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:none;align-items:center;justify-content:center;padding:24px}
.modal-overlay.show{display:flex}
.modal{background:white;border-radius:24px;padding:32px;width:100%;max-width:400px;position:relative}
.modal h2{font-family:'DM Serif Display',serif;font-size:26px;margin-bottom:8px}
.modal p{font-size:14px;color:var(--muted);margin-bottom:24px}
.modal-close{position:absolute;top:20px;right:20px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);line-height:1}
.modal input{width:100%;padding:14px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;font-family:'DM Sans',sans-serif;margin-bottom:12px;outline:none;transition:border-color 0.2s}
.modal input:focus{border-color:var(--green)}
.modal-btn{width:100%;padding:14px;background:var(--green);color:white;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity 0.2s}
.modal-btn:hover{opacity:0.9}
.modal-btn:disabled{opacity:0.6;cursor:not-allowed}
.modal-switch{text-align:center;margin-top:16px;font-size:13px;color:var(--muted)}
.modal-switch span{color:var(--green);cursor:pointer;font-weight:600}
.modal-error{color:var(--red);font-size:13px;margin-bottom:10px;padding:10px 14px;background:var(--red-light);border-radius:8px;display:none}

/* SUB BANNERS */
.banner-pro{background:var(--green-light);border-radius:12px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.banner-free{background:var(--amber-light);border-radius:12px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}

/* FOOTER */
footer{background:var(--dark);padding:40px 24px;text-align:center;margin-top:0}
footer p{font-size:13px;color:rgba(255,255,255,0.4);line-height:1.8}
footer a{color:rgba(255,255,255,0.5);text-decoration:none}

/* WRAP */
.page-wrap{max-width:700px;margin:0 auto;padding:40px 24px}

/* DETAIL PAGE */
.detail-icon{width:56px;height:56px;background:var(--green-light);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}
.detail-title{font-family:'DM Serif Display',serif;font-size:28px;margin-bottom:8px;line-height:1.3}
.detail-meta{font-size:13px;color:var(--muted);margin-bottom:16px}
.detail-body{font-size:15px;line-height:1.8;color:#44403c;margin-bottom:16px}
.detail-warning{background:var(--amber-light);border-left:3px solid var(--amber);padding:12px 16px;border-radius:0 10px 10px 0;font-size:13px;color:#78350f;line-height:1.6;margin-bottom:24px}
.back-btn{display:inline-flex;align-items:center;gap:8px;background:none;border:none;font-size:14px;color:var(--muted);cursor:pointer;font-family:'DM Sans',sans-serif;margin-bottom:24px;padding:0;text-decoration:none}
.back-btn:hover{color:var(--dark)}
.section-divider{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin:20px 0 12px}

@media(max-width:600px){
  .section-title{font-size:28px}
  .page-wrap{padding:24px 16px}
}
