/* Bucephalus Data Capture — shared design system */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --ink:#17212b;--forest:#1d5c40;--leaf:#0c8558;--mint:#8BC34A;
  --sage:#cfe4d6;--foam:#eefbf5;--warm-white:#fff;--amber:#d47424;
  --amber-light:#ff9d4d;--steel:#2d3329;--mist:#b8d4c8;--rule:#d4e8e0;
  --error:#c0392b;--shadow:0 10px 44px rgba(29,92,64,.14);
}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  font-family:'Poppins',sans-serif;
  background:#f4f7f9;
  color:var(--ink);
  min-height:100vh;
  padding:14px 10px 34px;
  line-height:1.6;
}

/* ── Document shell ── */
.doc{max-width:860px;margin:0 auto;background:var(--warm-white);border-radius:4px;overflow:hidden;box-shadow:var(--shadow);}
.hdr{background:linear-gradient(135deg,#0f2a1d 0%,#1d5c40 42%,#0c8558 100%);position:relative;}
.hdr-stripe{height:4px;background:linear-gradient(90deg,#8BC34A,#36eba7 40%,#0c8558);}
.hdr-inner{padding:18px 18px 16px;display:flex;flex-direction:column;gap:12px;}
.company-tag{font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:2.2px;text-transform:uppercase;color:var(--mint);opacity:.9;}
.doc-title{font-family:'Merriweather',serif;font-size:34px;font-weight:900;color:#fff;line-height:1.12;letter-spacing:.2px;}
.doc-sub{font-size:11px;color:var(--sage);margin-top:4px;line-height:1.45;}
.confidential{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:7px;letter-spacing:1.4px;color:#ffd09f;background:rgba(255,157,77,.12);border:1px solid rgba(255,157,77,.5);padding:3px 8px;border-radius:2px;margin-top:8px;text-transform:uppercase;}
.form-meta{background:rgba(255,255,255,.08);border:1px solid rgba(207,228,214,.28);border-radius:4px;padding:10px 12px;display:grid;grid-template-columns:1fr 1fr;gap:7px 14px;}
.meta-row{display:flex;flex-direction:column;gap:3px;}
.meta-lbl{font-family:'JetBrains Mono',monospace;font-size:7px;letter-spacing:1.4px;text-transform:uppercase;color:#e8f5ec;}
.meta-val{font-family:'JetBrains Mono',monospace;font-size:9px;color:#fff;font-weight:500;}
.hdr-tagline{padding:9px 18px;background:rgba(15,42,29,.5);border-top:1px solid rgba(255,255,255,.08);font-family:'Inter',sans-serif;font-size:11px;color:#eefbf5;font-weight:500;}
.logo-wrap{display:inline-flex;align-items:center;margin:0 0 8px;padding:6px 10px;border-radius:3px;}
.logo-img{max-width:165px;height:auto;display:block;}

/* ── Hub nav (index) ── */
.hub-nav{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px;background:var(--foam);border-bottom:1px solid var(--rule);}
.hub-nav a{font-size:11px;font-weight:600;text-decoration:none;color:var(--forest);padding:6px 10px;border:1px solid var(--rule);border-radius:3px;background:#fff;transition:all .2s;}
.hub-nav a:hover,.hub-nav a.active{background:var(--leaf);color:#fff;border-color:var(--leaf);}
.hub-nav a.active{cursor:default;}

/* ── Notices ── */
.notice{background:var(--foam);border-left:3px solid var(--mint);margin:16px 14px;padding:10px 12px;display:flex;gap:8px;border-radius:2px;}
.notice p{font-size:10.5px;color:#2d3329;line-height:1.55;}
.notice p strong{color:var(--forest);}
.notice-icon{font-size:15px;flex-shrink:0;margin-top:1px;}
.notice-warn{background:#fff5ea;border-left-color:var(--amber-light);}
.notice-warn p strong{color:#7a4200;}
.notice code{font-family:'JetBrains Mono',monospace;font-size:10px;background:rgba(0,0,0,.05);padding:1px 4px;border-radius:2px;}
.msg-box{display:none;padding:12px 14px;border-radius:3px;margin:14px 14px 0;font-size:12px;line-height:1.55;}
.msg-box.success{background:#eefbf5;border:1px solid #8BC34A;color:var(--forest);}
.msg-box.error{background:#fdf0e6;border:1px solid #e8c06a;color:#7a4200;}

/* ── Progress wizard ── */
.wizard-progress{padding:16px 14px 12px;border-bottom:1px solid var(--rule);background:linear-gradient(180deg,#fff 0%,var(--foam) 100%);}
.wizard-progress-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap;}
.wizard-progress-title{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--forest);display:flex;align-items:center;gap:6px;}
.wizard-stats{display:flex;gap:12px;font-size:10px;color:#5f6f7f;font-family:'JetBrains Mono',monospace;}
.progress-bar-track{height:6px;background:var(--rule);border-radius:99px;overflow:hidden;margin-bottom:12px;}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--leaf),var(--mint));border-radius:99px;transition:width .35s ease;}
.step-indicators{display:flex;flex-wrap:wrap;gap:6px;}
.step-indicator{
  flex:1;min-width:72px;padding:6px 4px;text-align:center;border:1px solid var(--rule);
  border-radius:3px;background:#fff;cursor:pointer;transition:all .2s;
}
.step-indicator .step-number{
  display:block;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:600;
  color:var(--leaf);margin-bottom:2px;
}
.step-indicator .step-name{display:block;font-size:8px;font-weight:600;color:#5f6f7f;text-transform:uppercase;letter-spacing:.3px;line-height:1.2;}
.step-indicator.active{border-color:var(--leaf);background:var(--foam);box-shadow:0 2px 8px rgba(12,133,88,.12);}
.step-indicator.active .step-name{color:var(--forest);}
.step-indicator.completed{border-color:var(--mint);background:#f8fff9;}
.step-indicator.completed .step-number{color:var(--mint);}

/* ── Form steps ── */
.form-content{padding:0 14px 14px;}
.form-step{display:none;animation:fadeUp .35s ease;}
.form-step.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
.step-header{margin:16px 0 14px;padding-bottom:12px;border-bottom:1px solid var(--foam);}
.step-title{font-family:'Merriweather',serif;font-size:18px;font-weight:700;color:var(--forest);display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.step-title i{color:var(--leaf);font-size:16px;}
.step-description{font-size:12px;color:#5f6f7f;line-height:1.55;}

/* ── Fields ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-group.full-width{grid-column:1/-1;}
.form-group label{
  font-size:10px;font-weight:700;letter-spacing:.55px;text-transform:uppercase;color:var(--steel);
  display:flex;align-items:center;gap:5px;
}
.form-group label i{color:var(--leaf);font-size:11px;width:14px;text-align:center;}
.req{color:var(--amber);margin-left:2px;}
.input,.form-group select,.form-group textarea{
  border:none;border-bottom:1.5px solid var(--mist);background:transparent;
  padding:8px 0 5px;font-family:'Inter',sans-serif;font-size:13px;color:var(--ink);
  outline:none;width:100%;border-radius:0;
}
.form-group select{
  padding-right:22px;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%234d6765'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 4px center;
  -webkit-appearance:none;appearance:none;
}
.form-group textarea{min-height:72px;resize:vertical;border:1.5px solid var(--mist);border-radius:3px;padding:9px 10px;}
.input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--leaf);}
.input::placeholder,.form-group textarea::placeholder{color:#5f6f7f;font-size:11px;}
.field-hint{font-size:9px;color:#5f6f7f;font-style:italic;}
.error-message{font-size:10px;color:var(--error);display:none;}
.error-message.show{display:block;}
.input.error,.form-group select.error,.form-group textarea.error{border-color:var(--error);}

/* ── Info boxes ── */
.info-box,.privacy-notice{
  background:var(--foam);border-left:3px solid var(--mint);padding:10px 12px;
  border-radius:2px;font-size:11px;color:#2d3329;line-height:1.55;display:flex;gap:8px;align-items:flex-start;
}
.info-box i,.privacy-notice i{color:var(--leaf);margin-top:2px;}
.info-box-content h4{font-size:11px;font-weight:700;color:var(--forest);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px;}
.mt-20{margin-top:16px;}

/* ── Checklist table ── */
.checklist-table{width:100%;border-collapse:collapse;font-size:11px;margin-top:8px;}
.checklist-table th{
  background:linear-gradient(90deg,#1d5c40,#0c8558);color:#fff;padding:8px 10px;
  text-align:left;font-size:9px;letter-spacing:.5px;text-transform:uppercase;font-weight:600;
}
.checklist-table td{padding:8px 10px;border-bottom:1px solid var(--rule);vertical-align:middle;}
.checklist-table tr:hover td{background:var(--foam);}
.checklist-table td i{color:var(--leaf);margin-right:4px;}

/* ── Navigation buttons ── */
.form-navigation{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--foam);
}
.btn{
  font-family:'Poppins',sans-serif;font-size:12px;font-weight:600;cursor:pointer;
  border-radius:4px;padding:11px 18px;display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border:none;transition:all .2s;letter-spacing:.2px;
}
.btn-primary{background:var(--forest);color:#fff;flex:1;min-width:140px;}
.btn-primary:hover{background:var(--leaf);}
.btn-secondary{background:#fff;color:var(--forest);border:1.5px solid var(--forest);}
.btn-secondary:hover{background:var(--foam);}
.btn-save-draft{background:var(--foam);color:var(--forest);border:1.5px solid var(--rule);}
.btn-save-draft:hover{border-color:var(--leaf);}
.btn:disabled{opacity:.65;cursor:not-allowed;}

/* ── Loading overlay ── */
.loading-overlay{
  display:none;position:fixed;inset:0;background:rgba(15,42,29,.72);z-index:9999;
  align-items:center;justify-content:center;
}
.loading-overlay.show{display:flex;}
.loading-content{background:#fff;padding:28px 32px;border-radius:4px;text-align:center;max-width:340px;box-shadow:var(--shadow);}
.loading-content h3{font-family:'Merriweather',serif;font-size:16px;color:var(--forest);margin:12px 0 6px;}
.loading-content p{font-size:12px;color:#5f6f7f;}
.spinner{
  width:40px;height:40px;border:3px solid var(--rule);border-top-color:var(--leaf);
  border-radius:50%;animation:spin .8s linear infinite;margin:0 auto;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── Footer ── */
.doc-footer{
  background:linear-gradient(135deg,#0f2a1d 0%,#1d5c40 70%,#0c8558 100%);
  padding:14px 16px;display:flex;flex-direction:column;gap:6px;margin-top:4px;
}
.f-brand{font-family:'Merriweather',serif;font-size:12px;font-weight:700;color:#fff;}
.f-sub{font-size:9px;color:#e8f5ec;line-height:1.5;}
.f-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px;}
.f-links a{font-size:9px;color:var(--mint);text-decoration:none;}
.f-links a:hover{text-decoration:underline;}
.f-tag{font-family:'JetBrains Mono',monospace;font-size:7px;letter-spacing:1.3px;color:#cfe4d6;margin-top:4px;}

/* ── Hero features strip ── */
.hero-features{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.hero-feature{
  font-size:10px;color:#e8f5ec;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  padding:5px 10px;border-radius:99px;display:flex;align-items:center;gap:5px;
}
.hero-feature i{color:var(--mint);}

/* ── Hub cards (index) ── */
.hub-cards{display:grid;grid-template-columns:1fr;gap:12px;padding:16px 14px 20px;}
.hub-card{
  border:1px solid var(--rule);border-radius:4px;padding:16px;background:#fff;
  text-decoration:none;color:inherit;transition:all .2s;display:block;
}
.hub-card:hover{border-color:var(--leaf);box-shadow:0 4px 16px rgba(12,133,88,.1);transform:translateY(-1px);}
.hub-card-tag{font-family:'JetBrains Mono',monospace;font-size:7px;letter-spacing:1.5px;text-transform:uppercase;color:var(--leaf);margin-bottom:6px;}
.hub-card h2{font-family:'Merriweather',serif;font-size:17px;color:var(--forest);margin-bottom:6px;}
.hub-card p{font-size:11px;color:#5f6f7f;line-height:1.5;}
.hub-card-cta{margin-top:10px;font-size:11px;font-weight:600;color:var(--leaf);}

/* ── Responsive ── */
@media(min-width:768px){
  body{padding:22px 14px 42px;}
  .hdr-inner{flex-direction:row;align-items:flex-start;justify-content:space-between;}
  .hdr-left{flex:1;}
  .form-meta{min-width:220px;flex-shrink:0;}
  .hub-cards{grid-template-columns:1fr 1fr;}
  .hub-cards .hub-card:first-child{grid-column:1/-1;}
}
@media(max-width:767px){
  .doc-title{font-size:26px;}
  .form-grid{grid-template-columns:1fr;}
  .step-indicators{gap:4px;}
  .step-indicator{min-width:58px;padding:5px 3px;}
  .step-indicator .step-name{font-size:7px;}
  .form-navigation{flex-direction:column;}
  .btn{width:100%;}
  .checklist-table{font-size:10px;}
  .checklist-table th,.checklist-table td{padding:6px 8px;}
}
