/* PAGE HEADER */
.page-header{background:var(--forest);padding:52px 32px 64px;position:relative;overflow:hidden;}
.page-header::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 50%,rgba(116,198,157,.12) 0%,transparent 55%);pointer-events:none;}
.ph-inner{max-width:900px;margin:0 auto;position:relative;z-index:1;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12.5px;color:rgba(255,255,255,.5);margin-bottom:20px;}
.breadcrumb a{color:rgba(255,255,255,.5);text-decoration:none;}
.breadcrumb a:hover{color:var(--sage);}
.breadcrumb span{color:rgba(255,255,255,.3);}
.page-header h1{font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,44px);color:var(--white);margin-bottom:14px;line-height:1.2;}
.page-header p{color:rgba(255,255,255,.65);font-size:15.5px;max-width:580px;line-height:1.75;}

/* TIMELINE OVERVIEW BAR */
.overview-bar{background:var(--white);border-bottom:1px solid var(--border);padding:20px 32px;position:sticky;top:108px;z-index:90;box-shadow:var(--shadow-sm);}
.overview-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:0;overflow-x:auto;}
.ov-step{display:flex;align-items:center;gap:0;flex-shrink:0;}
.ov-dot{width:32px;height:32px;border-radius:50%;background:var(--sand-dark);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--ink-muted);transition:all .3s;cursor:pointer;flex-shrink:0;}
.ov-dot:hover,.ov-dot.active{background:var(--forest);border-color:var(--forest);color:var(--white);}
.ov-label{font-size:11px;font-weight:600;color:var(--ink-muted);margin-left:8px;white-space:nowrap;}
.ov-arrow{width:40px;height:2px;background:var(--border);margin:0 8px;flex-shrink:0;}

/* MAIN */
.main{max-width:900px;margin:0 auto;padding:56px 32px 80px;}

/* SECTION LABEL */
.sec-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--forest-light);margin-bottom:8px;}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(22px,3vw,32px);color:var(--forest);margin-bottom:12px;line-height:1.25;}
.sec-desc{color:var(--ink-muted);font-size:15px;line-height:1.8;margin-bottom:40px;max-width:640px;}

/* TIMELINE */
.timeline{position:relative;padding-left:52px;}
.timeline::before{content:'';position:absolute;left:22px;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--forest),var(--sage),var(--sage-pale));border-radius:3px;}

.tl-step{position:relative;margin-bottom:48px;}
.tl-step:last-child{margin-bottom:0;}

/* Step number bubble */
.tl-num{position:absolute;left:-52px;width:44px;height:44px;border-radius:50%;background:var(--forest);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:20px;font-weight:700;box-shadow:0 4px 14px rgba(27,67,50,.35);top:0;border:3px solid var(--sand);}

/* Step card */
.tl-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 28px 24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s;}
.tl-card:hover{box-shadow:var(--shadow-md);}
.tl-card-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px;}
.tl-icon{font-size:32px;flex-shrink:0;margin-top:2px;}
.tl-card-title h2{font-size:19px;font-weight:800;color:var(--forest);line-height:1.25;margin-bottom:4px;}
.tl-card-title .timing{font-size:12px;font-weight:600;color:var(--ink-muted);background:var(--sand);padding:3px 12px;border-radius:12px;display:inline-block;}

.tl-body{font-size:14.5px;color:var(--ink-mid);line-height:1.8;}
.tl-body p{margin-bottom:12px;}
.tl-body p:last-child{margin-bottom:0;}
.tl-body strong{color:var(--forest);}
.tl-body a{color:var(--forest-mid);font-weight:600;text-decoration:underline;}

/* Sub-steps */
.substep-list{list-style:none;margin:14px 0;display:flex;flex-direction:column;gap:10px;}
.substep-list li{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--sand);border-radius:var(--r-sm);font-size:14px;}
.substep-num{width:24px;height:24px;background:var(--forest-light);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0;margin-top:1px;}
.substep-text{color:var(--ink-mid);line-height:1.55;}
.substep-text strong{color:var(--forest);}

/* Check list */
.check-list{list-style:none;margin:12px 0;display:flex;flex-direction:column;gap:7px;}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-mid);}
.check-list li::before{content:'✓';color:var(--forest-light);font-weight:800;flex-shrink:0;margin-top:2px;}


/* Info / warn boxes */
.info-box{background:var(--sage-pale);border-left:4px solid var(--forest-light);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:13px 16px;margin:14px 0;font-size:13.5px;color:var(--forest);line-height:1.65;}
.warn-box{background:var(--terra-pale);border-left:4px solid var(--terra-light);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:13px 16px;margin:14px 0;font-size:13.5px;color:#7B2B00;line-height:1.65;}
.warn-box strong{color:var(--terra);}

/* Tags row */
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0;}
.tag{font-size:12px;font-weight:600;padding:5px 12px;border-radius:14px;background:var(--sand);border:1px solid var(--border);color:var(--ink-mid);}
.tag-required{background:var(--terra-pale);border-color:rgba(193,68,14,.25);color:#7B2B00;}
.tag-optional{background:var(--sage-pale);border-color:rgba(64,145,108,.25);color:var(--forest);}

/* Divider line between steps */
.tl-connector{height:28px;}

/* TIMELINE STATUS BADGE */
.step-status{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 12px;border-radius:12px;margin-top:10px;}
.status-when{background:rgba(27,67,50,.08);color:var(--forest);}

/* QUICK SUMMARY CARD */
.summary-card{background:var(--forest);border-radius:var(--r-lg);padding:28px 32px;margin-bottom:52px;color:var(--white);}
.summary-card h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--white);margin-bottom:16px;}
.summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.summary-item{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-md);padding:16px 18px;}
.summary-item .si-label{font-size:11px;color:rgba(255,255,255,.5);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px;}
.summary-item .si-val{font-size:18px;font-weight:800;color:var(--terra-light);line-height:1.2;}
.summary-item .si-note{font-size:12px;color:rgba(255,255,255,.55);margin-top:4px;line-height:1.5;}

/* CTA bottom */
.cta-bottom{background:linear-gradient(135deg,var(--terra) 0%,#8B2500 100%);border-radius:var(--r-lg);padding:36px 32px;text-align:center;margin-top:56px;}
.cta-bottom h3{font-family:'Playfair Display',serif;font-size:26px;color:var(--white);margin-bottom:10px;}
.cta-bottom p{color:rgba(255,255,255,.75);font-size:14.5px;margin-bottom:24px;line-height:1.7;}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.btn-sand{background:var(--sand);color:var(--terra);padding:12px 26px;border-radius:var(--r-sm);font-weight:800;font-size:14px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:transform .15s,box-shadow .15s;}
.btn-sand:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2);}
.btn-ghost-w{background:transparent;color:var(--white);padding:12px 26px;border-radius:var(--r-sm);font-weight:600;font-size:14px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;border:2px solid rgba(255,255,255,.45);transition:background .2s;}
.btn-ghost-w:hover{background:rgba(255,255,255,.1);}


/* FOOTER */
footer{padding:40px 32px 24px;}
.foot-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:32px;flex-wrap:wrap;margin-bottom:24px;}
.foot-brand .brand-name{font-size:20px;color:var(--white);display:block;margin-bottom:6px;}
.foot-brand p{line-height:1.7;max-width:300px;}
.foot-col h4{margin-bottom:10px;}
.foot-bottom{padding-top:18px;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;font-size:12px;flex-wrap:wrap;gap:8px;}

/* RESPONSIVE */
@media(max-width:768px){
  .main{padding:36px 20px 60px;}
  .page-header{padding:40px 20px 52px;}
  nav{padding:0 20px;}.nav-menu{display:none;}
  .topbar{padding:0 16px;}.topbar-note{display:none;}
  .overview-bar{padding:16px 20px;top:108px;}
  .timeline{padding-left:40px;}
  .timeline::before{left:16px;}
  .tl-num{left:-40px;width:34px;height:34px;font-size:16px;}
  .tl-card{padding:20px 18px;}
  .summary-row{grid-template-columns:1fr;}
  .disclaimer{padding:16px 20px;}
  ul.check-list li{display:revert !important;}
  ul.check-list li.ja{display:revert !important;}
}