*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ivory:#FAFAF6;--ivory2:#F3F2ED;--ivory3:#E8E6DF;
  --ink:#1C1917;--ink2:#57534E;--ink3:#A8A29E;
  --amber:#B45309;--amber-light:#FEF3C7;--amber-mid:#FDE68A;
  --green:#065F46;--green-bg:#ECFDF5;--green-mid:#9FE1CB;
  --red:#991B1B;--red-bg:#FEF2F2;--red-mid:#FCA5A5;
  --white:#FFFFFF;
}
html,body{background:var(--ivory2);color:var(--ink);font-family:-apple-system,'Helvetica Neue',Helvetica,sans-serif;font-size:14px;line-height:1.55;min-height:100vh}
.serif{font-family:Georgia,'Times New Roman',serif}
a{color:var(--amber);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}

/* Top nav */
.appnav{background:var(--white);border-bottom:1px solid var(--ivory3);height:56px;display:flex;align-items:center;padding:0 24px;gap:24px;position:sticky;top:0;z-index:50}
.appnav-logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.appnav-logo-icon{width:26px;height:26px;background:var(--amber);border-radius:5px;display:flex;align-items:center;justify-content:center}
.appnav-logo-icon svg{width:14px;height:14px;fill:white}
.appnav-logo-name{font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.2px}
.appnav-tabs{display:flex;gap:4px;margin-left:8px}
.appnav-tab{padding:8px 14px;font-size:13px;font-weight:500;color:var(--ink2);border-radius:6px;text-decoration:none;display:flex;align-items:center;gap:7px}
.appnav-tab:hover{background:var(--ivory2);color:var(--ink);text-decoration:none}
.appnav-tab.active{background:var(--ink);color:var(--white)}
.appnav-tab.active:hover{background:var(--ink)}
.appnav-tab .badge{background:var(--amber);color:white;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;line-height:1.4}
.appnav-tab.active .badge{background:var(--amber)}
.appnav-spacer{flex:1}
.appnav-search{background:var(--ivory2);border:1px solid var(--ivory3);border-radius:7px;padding:7px 12px;font-size:13px;color:var(--ink2);width:240px;outline:none}
.appnav-search:focus{border-color:var(--amber);background:var(--white)}
.appnav-bell{position:relative;width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--ink2);background:none;border:none}
.appnav-bell:hover{background:var(--ivory2)}
.appnav-bell svg{width:18px;height:18px}
.appnav-bell .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;background:var(--amber);border-radius:50%;border:2px solid var(--white)}
.appnav-avatar{width:32px;height:32px;border-radius:50%;background:var(--amber);color:white;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;text-decoration:none}
.appnav-avatar:hover{text-decoration:none}

/* Page shell */
.page{max-width:1180px;margin:0 auto;padding:32px 24px 80px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:24px;flex-wrap:wrap}
.page-title-block .breadcrumb{font-size:12px;color:var(--ink3);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.page-title-block .breadcrumb a{color:var(--ink3)}
.page-title-block .breadcrumb a:hover{color:var(--ink2);text-decoration:none}
.page-title-block .breadcrumb-sep{color:var(--ink3)}
.page-title{font-family:Georgia,serif;font-size:30px;font-weight:700;color:var(--ink);line-height:1.2;letter-spacing:-.4px}
.page-subtitle{font-size:13px;color:var(--ink2);margin-top:6px}
.page-actions{display:flex;gap:8px;align-items:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:7px;font-size:13px;font-weight:600;border:1px solid transparent;text-decoration:none;cursor:pointer;line-height:1.2}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--ink);color:var(--white)}
.btn-primary:hover{background:#292524}
.btn-amber{background:var(--amber);color:var(--white)}
.btn-amber:hover{background:#92400E}
.btn-outline{background:var(--white);color:var(--ink);border-color:var(--ivory3)}
.btn-outline:hover{border-color:var(--ink3)}
.btn-ghost{background:transparent;color:var(--ink2)}
.btn-ghost:hover{background:var(--ivory2);color:var(--ink)}
.btn-sm{padding:6px 11px;font-size:12px}
.btn svg{width:14px;height:14px}

/* Stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}
.stat{background:var(--white);border:1px solid var(--ivory3);border-radius:10px;padding:16px 18px}
.stat-l{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);margin-bottom:6px}
.stat-n{font-size:26px;font-weight:700;color:var(--ink);line-height:1.1}
.stat-n.amber{color:var(--amber)}
.stat-n.green{color:var(--green)}
.stat-n.red{color:var(--red)}
.stat-sub{font-size:11px;color:var(--ink3);margin-top:4px}

/* Cards */
.card{background:var(--white);border:1px solid var(--ivory3);border-radius:12px;padding:20px}
.card-row{background:var(--white);border:1px solid var(--ivory3);border-radius:10px;padding:18px 20px;margin-bottom:10px;transition:border-color .15s}
.card-row:hover{border-color:var(--ink3)}
.card-row:last-child{margin-bottom:0}
.card-h{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:12px}
.card-h-sm{font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--ink3);margin-bottom:14px}

/* Pills */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.2px}
.pill-active{background:var(--green-bg);color:var(--green)}
.pill-warn{background:var(--amber-light);color:var(--amber)}
.pill-exp{background:var(--red-bg);color:var(--red)}
.pill-info{background:var(--ivory2);color:var(--ink2)}
.pill-dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.pill-dot.green{background:var(--green)}
.pill-dot.amber{background:var(--amber)}
.pill-dot.red{background:#DC2626}

/* Filter tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--ivory3);margin-bottom:18px}
.tab{padding:10px 14px;font-size:13px;font-weight:500;color:var(--ink2);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:7px}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--ink);border-color:var(--amber);font-weight:600}
.tab .count{font-size:11px;color:var(--ink3);background:var(--ivory2);padding:1px 7px;border-radius:10px;font-weight:600}
.tab.active .count{background:var(--amber-light);color:var(--amber)}

/* Project health bar (segmented) */
.health{height:7px;border-radius:4px;overflow:hidden;display:flex;background:var(--ivory3)}
.health-seg{height:100%}
.health-active{background:var(--green-mid)}
.health-warn{background:var(--amber-mid)}
.health-exp{background:var(--red-mid)}
.health-legend{display:flex;gap:14px;font-size:11px;color:var(--ink3);margin-top:8px}
.health-legend span{display:flex;align-items:center;gap:5px}

/* Two-column layout */
.two-col{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:flex-start}

/* Definition list */
.dl{display:grid;grid-template-columns:140px 1fr;gap:14px 20px}
.dl dt{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);align-self:center}
.dl dd{font-size:14px;color:var(--ink);font-weight:500}

/* Timeline visual */
.warr-timeline{background:var(--ivory2);border-radius:10px;padding:24px 20px;margin-top:20px}
.warr-timeline-track{position:relative;height:8px;background:var(--ivory3);border-radius:4px;margin:30px 0 24px}
.warr-timeline-fill{position:absolute;left:0;top:0;height:100%;background:var(--amber);border-radius:4px}
.warr-timeline-mark{position:absolute;top:-6px;width:2px;height:20px;background:var(--ink)}
.warr-timeline-mark.now{background:var(--amber);width:3px;height:22px;top:-7px}
.warr-timeline-label{position:absolute;font-size:10px;color:var(--ink2);transform:translateX(-50%);top:-26px;white-space:nowrap;font-weight:600}
.warr-timeline-label.now{color:var(--amber);font-weight:700}
.warr-timeline-foot{display:flex;justify-content:space-between;font-size:11px;color:var(--ink3)}

/* Document & vendor lists */
.doc-list{display:flex;flex-direction:column;gap:8px}
.doc-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--ivory3);border-radius:8px;background:var(--white)}
.doc-row:hover{border-color:var(--ink3)}
.doc-icon{width:30px;height:30px;background:var(--red-bg);color:var(--red);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.doc-meta{flex:1;min-width:0}
.doc-name{font-size:13px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.doc-sub{font-size:11px;color:var(--ink3)}

.vendor-card{display:flex;flex-direction:column;gap:10px}
.vendor-name{font-size:14px;font-weight:700;color:var(--ink)}
.vendor-line{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink2)}
.vendor-line svg{width:14px;height:14px;color:var(--ink3);flex-shrink:0}

/* Activity log */
.activity{display:flex;flex-direction:column;gap:14px;position:relative}
.activity-item{display:flex;gap:12px;align-items:flex-start}
.activity-dot{width:9px;height:9px;border-radius:50%;background:var(--ivory3);margin-top:6px;flex-shrink:0;border:2px solid var(--white);box-shadow:0 0 0 1px var(--ivory3)}
.activity-dot.amber{background:var(--amber);box-shadow:0 0 0 1px var(--amber)}
.activity-dot.green{background:var(--green);box-shadow:0 0 0 1px var(--green)}
.activity-body{flex:1}
.activity-title{font-size:13px;color:var(--ink);font-weight:500}
.activity-meta{font-size:11px;color:var(--ink3);margin-top:2px}

/* Alerts list */
.alert-row{background:var(--white);border:1px solid var(--ivory3);border-left:3px solid var(--ink3);border-radius:8px;padding:16px 18px;margin-bottom:10px;display:flex;align-items:flex-start;gap:14px}
.alert-row.amber-l{border-left-color:var(--amber);background:linear-gradient(to right,#FFFBEB 0%,var(--white) 80px)}
.alert-row.red-l{border-left-color:#DC2626;background:linear-gradient(to right,#FEF2F2 0%,var(--white) 80px)}
.alert-row.green-l{border-left-color:var(--green);background:linear-gradient(to right,var(--green-bg) 0%,var(--white) 80px)}
.alert-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--ivory2)}
.alert-icon.amber-i{background:var(--amber-light);color:var(--amber)}
.alert-icon.red-i{background:var(--red-bg);color:var(--red)}
.alert-icon.green-i{background:var(--green-bg);color:var(--green)}
.alert-icon svg{width:16px;height:16px}
.alert-body{flex:1;min-width:0}
.alert-type{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--ink3);margin-bottom:4px}
.alert-type.amber-t{color:var(--amber)}
.alert-type.red-t{color:var(--red)}
.alert-type.green-t{color:var(--green)}
.alert-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}
.alert-sub{font-size:13px;color:var(--ink2);margin-bottom:10px}
.alert-actions{display:flex;gap:6px;flex-wrap:wrap}
.alert-time{font-size:11px;color:var(--ink3);white-space:nowrap;flex-shrink:0}

/* Project list rows */
.proj-row{background:var(--white);border:1px solid var(--ivory3);border-radius:12px;padding:20px 22px;margin-bottom:12px;transition:all .15s}
.proj-row:hover{border-color:var(--ink3)}
.proj-row-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.proj-name{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:4px}
.proj-meta{font-size:12px;color:var(--ink3)}
.proj-stats{display:flex;gap:24px;font-size:12px;color:var(--ink2);margin-top:12px;align-items:center;flex-wrap:wrap}
.proj-stats strong{color:var(--ink);font-weight:700}
.proj-next{font-size:12px;color:var(--amber);font-weight:600;display:flex;align-items:center;gap:6px;margin-top:8px}

/* Claims table */
.claims-table{background:var(--white);border:1px solid var(--ivory3);border-radius:12px;overflow:hidden}
.claim-row{padding:18px 22px;border-bottom:1px solid var(--ivory3);display:grid;grid-template-columns:2fr 1fr 1fr 1fr 100px;gap:18px;align-items:center}
.claim-row:last-child{border-bottom:none}
.claim-row:hover{background:var(--ivory2)}
.claim-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px}
.claim-link{font-size:11px;color:var(--ink3)}
.claim-link a{color:var(--ink3)}
.claim-cell-l{font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.claim-cell-v{font-size:13px;color:var(--ink2)}
.claim-row.head{background:var(--ivory2);padding:12px 22px}
.claim-row.head .claim-cell-l{margin-bottom:0}

/* Empty state */
.empty{max-width:680px;margin:48px auto 0;text-align:center;background:var(--white);border:1px solid var(--ivory3);border-radius:16px;padding:56px 40px}
.empty-icon{width:62px;height:62px;background:var(--amber-light);color:var(--amber);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.empty-icon svg{width:28px;height:28px}
.empty-h{font-family:Georgia,serif;font-size:24px;font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:10px}
.empty-sub{font-size:14px;color:var(--ink2);line-height:1.65;max-width:440px;margin:0 auto 28px}
.empty-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:520px;margin:0 auto}
.empty-action{background:var(--ivory2);border-radius:12px;padding:22px 20px;text-decoration:none;color:inherit;display:block;text-align:left;border:1px solid transparent;transition:all .15s}
.empty-action:hover{background:var(--white);border-color:var(--amber);text-decoration:none}
.empty-action-h{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.empty-action-h svg{width:18px;height:18px;color:var(--amber)}
.empty-action-d{font-size:12px;color:var(--ink2);line-height:1.55}
.empty-foot{margin-top:32px;font-size:12px;color:var(--ink3)}
.empty-foot a{color:var(--amber)}

/* Audit log */
.audit-row{background:var(--white);border:1px solid var(--ivory3);border-top:none;padding:14px 18px;display:grid;grid-template-columns:160px 30px 1fr 110px;gap:14px;align-items:center;font-size:13px}
.audit-row:first-child{border-top:1px solid var(--ivory3);border-radius:10px 10px 0 0}
.audit-row:last-child{border-radius:0 0 10px 10px}
.audit-row.head{background:var(--ivory2);font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);border-radius:10px 10px 0 0}
.audit-time{color:var(--ink3);font-size:12px}
.audit-time strong{display:block;color:var(--ink);font-size:13px;font-weight:500}
.audit-actor{width:28px;height:28px;border-radius:50%;background:var(--amber);color:white;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center}
.audit-action strong{color:var(--ink);font-weight:600}
.audit-action a{color:var(--amber)}
.audit-meta{font-size:11px;color:var(--ink3)}
.audit-type{font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;padding:2px 8px;border-radius:10px;background:var(--ivory2);color:var(--ink3);text-align:center;display:inline-block}
.audit-type.create{background:var(--green-bg);color:var(--green)}
.audit-type.update{background:var(--amber-light);color:var(--amber)}
.audit-type.delete{background:var(--red-bg);color:var(--red)}
.audit-type.view{background:var(--ivory2);color:var(--ink3)}
.audit-type.send{background:#EFF6FF;color:#1E40AF}

/* Owner handover binder */
.binder-cover{padding:80px 0 60px;text-align:center;border-bottom:2px solid var(--ink);margin-bottom:36px}
.binder-cover-tag{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);margin-bottom:18px}
.binder-cover-title{font-family:Georgia,serif;font-size:38px;font-weight:700;color:var(--ink);line-height:1.15;letter-spacing:-.5px;margin-bottom:12px}
.binder-cover-sub{font-size:14px;color:var(--ink2);margin-bottom:30px}
.binder-cover-meta{display:inline-block;text-align:left;background:var(--ivory2);border-radius:8px;padding:18px 26px;font-size:13px;color:var(--ink2);line-height:2}
.binder-cover-meta strong{color:var(--ink);font-weight:600;margin-right:6px}

.binder-toc{background:var(--ivory2);border-radius:8px;padding:18px 22px;margin-bottom:34px}
.binder-toc-h{font-family:Georgia,serif;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:10px;letter-spacing:.3px;text-transform:uppercase}
.binder-toc-list{display:flex;flex-direction:column;gap:6px}
.binder-toc-item{display:flex;justify-content:space-between;font-size:13px;color:var(--ink2)}
.binder-toc-item strong{color:var(--ink);font-weight:500}

.binder-section{margin-bottom:38px}
.binder-section-h{font-family:Georgia,serif;font-size:20px;font-weight:700;color:var(--ink);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--ivory3);display:flex;justify-content:space-between;align-items:baseline}
.binder-section-h .pgnum{font-size:11px;color:var(--ink3);font-family:-apple-system,sans-serif;font-weight:500}

.binder-vendor-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.binder-vendor-card{background:var(--ivory2);border-radius:8px;padding:16px 18px;font-size:12px}
.binder-vendor-name{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:3px}
.binder-vendor-cat{color:var(--amber);font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;margin-bottom:10px}
.binder-vendor-line{color:var(--ink2);margin-bottom:3px}
.binder-vendor-line strong{color:var(--ink);font-weight:600;display:inline-block;min-width:50px}

.binder-cheat{background:var(--amber-light);border:1px solid var(--amber-mid);border-radius:8px;padding:18px 22px;margin-bottom:22px}
.binder-cheat-h{font-size:14px;font-weight:700;color:#78350F;margin-bottom:10px}
.binder-cheat-list{font-size:13px;color:#78350F;line-height:1.85;padding-left:18px}
.binder-cheat-list strong{color:var(--ink);font-weight:700}

.binder-cal{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.binder-cal-month{background:var(--white);border:1px solid var(--ivory3);border-radius:6px;padding:12px}
.binder-cal-month-h{font-size:11px;font-weight:700;color:var(--ink);margin-bottom:6px}
.binder-cal-event{font-size:10px;color:var(--ink2);margin-bottom:3px;line-height:1.4}
.binder-cal-event.warn{color:var(--amber);font-weight:600}
.binder-cal-event.exp{color:var(--red);font-weight:600}

/* Vendor scorecard */
.score-rank{display:grid;grid-template-columns:30px 2fr 90px 90px 90px 90px;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid var(--ivory3);font-size:13px}
.score-rank.head{font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);padding:10px 0}
.score-rank-num{font-size:18px;font-weight:700;color:var(--ink3);text-align:center}
.score-rank-num.top{color:var(--amber)}
.score-rank-name{font-size:14px;font-weight:600;color:var(--ink)}
.score-rank-cat{font-size:11px;color:var(--ink3);margin-top:2px}
.score-bar-wrap{position:relative}
.score-bar-bg{height:6px;background:var(--ivory2);border-radius:3px;margin-top:6px}
.score-bar-fill{height:100%;border-radius:3px;background:var(--green-mid)}
.score-bar-fill.warn{background:var(--amber-mid)}
.score-bar-fill.bad{background:var(--red-mid)}
.score-cell-v{font-weight:600;color:var(--ink)}
.score-cell-sub{font-size:10px;color:var(--ink3)}
.score-spark{display:inline-flex;gap:2px;align-items:flex-end;height:18px;margin-left:8px}
.score-spark span{width:4px;background:var(--green);border-radius:1px}

.score-callouts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.score-callout{background:var(--ivory2);border-radius:8px;padding:16px 18px}
.score-callout.win{background:var(--green-bg)}
.score-callout.warn{background:var(--amber-light)}
.score-callout-l{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);margin-bottom:6px}
.score-callout.win .score-callout-l{color:var(--green)}
.score-callout.warn .score-callout-l{color:var(--amber)}
.score-callout-h{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:4px}
.score-callout-sub{font-size:12px;color:var(--ink2);line-height:1.55}

/* Search results */
.search-h{font-family:Georgia,serif;font-size:24px;font-weight:700;color:var(--ink);margin-bottom:6px}
.search-q{color:var(--amber);font-style:italic}
.search-section{margin-bottom:34px}
.search-section-h{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);margin-bottom:12px;display:flex;justify-content:space-between;align-items:baseline}
.search-section-h .count{color:var(--ink2);font-weight:500}
.search-result{background:var(--white);border:1px solid var(--ivory3);border-radius:10px;padding:14px 18px;margin-bottom:8px;display:block;text-decoration:none;color:inherit}
.search-result:hover{border-color:var(--ink3);text-decoration:none}
.search-result-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}
.search-result-title mark{background:var(--amber-light);color:var(--ink);padding:0 2px;border-radius:2px}
.search-result-meta{font-size:12px;color:var(--ink3)}

/* Report preview / printable */
.preview-wrap{background:var(--ivory2);padding:32px 20px;min-height:calc(100vh - 56px)}
.preview-doc{max-width:820px;margin:0 auto;background:var(--white);border:1px solid var(--ivory3);border-radius:8px;padding:48px 56px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.preview-toolbar{max-width:820px;margin:0 auto 16px;display:flex;justify-content:space-between;align-items:center;background:var(--white);border:1px solid var(--ivory3);border-radius:8px;padding:10px 16px}
.preview-toolbar-info{font-size:12px;color:var(--ink3)}
.preview-doc-head{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:2px solid var(--ink);padding-bottom:18px;margin-bottom:24px}
.preview-doc-title{font-family:Georgia,serif;font-size:26px;font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:4px}
.preview-doc-sub{font-size:12px;color:var(--ink2)}
.preview-doc-meta{text-align:right;font-size:11px;color:var(--ink3)}
.preview-doc-meta strong{display:block;color:var(--ink);font-size:13px;font-weight:700}
.preview-summary{background:var(--ivory2);border-radius:8px;padding:18px 20px;margin-bottom:28px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.preview-summary-cell .l{font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3)}
.preview-summary-cell .n{font-size:22px;font-weight:700;color:var(--ink);line-height:1.1;margin-top:4px}
.preview-section{margin-bottom:28px}
.preview-section-h{font-family:Georgia,serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--ivory3)}
.preview-table{width:100%;border-collapse:collapse;font-size:12px}
.preview-table th{text-align:left;padding:8px 10px;font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--ink3);border-bottom:1px solid var(--ivory3)}
.preview-table td{padding:9px 10px;border-bottom:1px solid var(--ivory3);color:var(--ink2);vertical-align:top}
.preview-table td strong{color:var(--ink);font-weight:600;display:block}
.preview-table td .sub{font-size:10px;color:var(--ink3)}
.preview-foot{margin-top:36px;padding-top:18px;border-top:1px solid var(--ivory3);font-size:10px;color:var(--ink3);display:flex;justify-content:space-between}
@media print{
  .appnav,.preview-toolbar,.preview-wrap{background:white !important;padding:0 !important;box-shadow:none !important}
  .preview-doc{border:none;box-shadow:none;padding:30px 0}
}

/* Auth pages */
.auth-shell{min-height:100vh;background:var(--ivory);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px;text-decoration:none}
.auth-logo-icon{width:32px;height:32px;background:var(--amber);border-radius:6px;display:flex;align-items:center;justify-content:center}
.auth-logo-icon svg{width:16px;height:16px;fill:white}
.auth-logo-name{font-size:17px;font-weight:700;letter-spacing:-.3px;color:var(--ink)}
.auth-card{background:var(--white);border:1px solid var(--ivory3);border-radius:14px;padding:36px 38px;width:100%;max-width:420px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.auth-card.wide{max-width:520px}
.auth-h{font-family:Georgia,serif;font-size:24px;font-weight:700;color:var(--ink);margin-bottom:6px;letter-spacing:-.3px}
.auth-sub{font-size:13px;color:var(--ink2);margin-bottom:24px;line-height:1.55}
.auth-row{margin-bottom:14px}
.auth-row:last-of-type{margin-bottom:0}
.auth-label{display:block;font-size:12px;font-weight:600;color:var(--ink);margin-bottom:6px}
.auth-label-row{display:flex;justify-content:space-between;align-items:baseline}
.auth-label-row a{font-size:11px;color:var(--amber)}
.auth-input{width:100%;padding:11px 13px;font-size:14px;border:1px solid var(--ivory3);border-radius:8px;font-family:inherit;color:var(--ink);outline:none}
.auth-input:focus{border-color:var(--amber)}
.auth-btn{width:100%;padding:13px;background:var(--amber);color:white;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;margin-top:18px;font-family:inherit}
.auth-btn:hover{background:#92400E}
.auth-btn.outline{background:var(--white);color:var(--ink);border:1px solid var(--ivory3);margin-top:8px}
.auth-btn.outline:hover{border-color:var(--ink3)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--ink3);font-size:11px;text-transform:uppercase;letter-spacing:.6px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--ivory3)}
.auth-foot{text-align:center;font-size:13px;color:var(--ink2);margin-top:22px}
.auth-foot a{color:var(--amber);font-weight:600}
.auth-pill{display:inline-flex;align-items:center;gap:6px;background:var(--amber-light);color:#78350F;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;margin-bottom:14px}

/* Onboarding wizard */
.wiz-shell{min-height:100vh;background:var(--ivory);padding:32px 20px 60px}
.wiz-progress{max-width:680px;margin:0 auto 28px;display:flex;align-items:center;gap:12px}
.wiz-step{flex:1;display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink3);font-weight:500}
.wiz-step-num{width:24px;height:24px;border-radius:50%;background:var(--ivory3);color:var(--ink2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.wiz-step.done .wiz-step-num{background:var(--green);color:white}
.wiz-step.active .wiz-step-num{background:var(--amber);color:white}
.wiz-step.active{color:var(--ink);font-weight:600}
.wiz-step-line{flex:1;height:1px;background:var(--ivory3)}
.wiz-card{background:var(--white);border:1px solid var(--ivory3);border-radius:14px;padding:36px 38px;max-width:680px;margin:0 auto}
.wiz-h{font-family:Georgia,serif;font-size:26px;font-weight:700;color:var(--ink);margin-bottom:6px;letter-spacing:-.3px}
.wiz-sub{font-size:14px;color:var(--ink2);line-height:1.6;margin-bottom:26px}
.wiz-foot{display:flex;justify-content:space-between;align-items:center;margin-top:26px;padding-top:20px;border-top:1px solid var(--ivory3)}

/* Schedule walkthrough */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;background:var(--ivory2);padding:8px;border-radius:10px}
.cal-day-h{font-size:10px;font-weight:600;text-align:center;color:var(--ink3);padding:6px 0;text-transform:uppercase;letter-spacing:.4px}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--ink2);border-radius:6px;cursor:pointer;background:var(--white);position:relative}
.cal-day:hover{background:var(--ivory3)}
.cal-day.muted{color:var(--ink3);background:transparent}
.cal-day.today{font-weight:700;color:var(--amber)}
.cal-day.deadline{background:var(--red-bg);color:var(--red);font-weight:600}
.cal-day.recommended{background:var(--amber-light);color:var(--amber);font-weight:600}
.cal-day.selected{background:var(--ink);color:white;font-weight:700}

/* Claim detail thread */
.thread{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.thread-msg{background:var(--white);border:1px solid var(--ivory3);border-radius:10px;padding:16px 18px}
.thread-msg.me{background:var(--ivory2);border-color:var(--ivory3)}
.thread-msg-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;gap:14px}
.thread-msg-from{font-size:13px;font-weight:700;color:var(--ink)}
.thread-msg-from .role{font-weight:500;color:var(--ink3);font-size:11px;margin-left:6px}
.thread-msg-time{font-size:11px;color:var(--ink3)}
.thread-msg-body{font-size:13px;color:var(--ink2);line-height:1.65;white-space:pre-line}
.thread-msg-attach{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
.thread-msg-attach a{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink2);background:var(--white);border:1px solid var(--ivory3);padding:4px 9px;border-radius:6px;text-decoration:none}
.thread-msg-attach a:hover{border-color:var(--ink3)}

.status-rail{display:flex;align-items:center;justify-content:space-between;background:var(--white);border:1px solid var(--ivory3);border-radius:10px;padding:14px 18px;margin-bottom:18px}
.status-step{flex:1;text-align:center;position:relative;font-size:11px;color:var(--ink3);font-weight:500}
.status-step .dot{width:14px;height:14px;border-radius:50%;background:var(--ivory3);margin:0 auto 6px;display:flex;align-items:center;justify-content:center;color:white;font-size:9px;font-weight:700;border:3px solid var(--white);box-shadow:0 0 0 1px var(--ivory3)}
.status-step.done{color:var(--green)}
.status-step.done .dot{background:var(--green);box-shadow:0 0 0 1px var(--green)}
.status-step.active{color:var(--amber);font-weight:700}
.status-step.active .dot{background:var(--amber);box-shadow:0 0 0 1px var(--amber)}
.status-step:not(:last-child)::after{content:'';position:absolute;top:7px;left:calc(50% + 9px);right:calc(-50% + 9px);height:2px;background:var(--ivory3)}
.status-step.done:not(:last-child)::after{background:var(--green)}

/* Forms */
.form{max-width:780px;margin:0 auto}
.form-card{background:var(--white);border:1px solid var(--ivory3);border-radius:12px;padding:28px 30px;margin-bottom:18px}
.form-card-h{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px}
.form-card-sub{font-size:12px;color:var(--ink3);margin-bottom:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-row.single{grid-template-columns:1fr}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
.form-row:last-child{margin-bottom:0}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:12px;font-weight:600;color:var(--ink);display:flex;align-items:center;justify-content:space-between}
.form-label .req{color:var(--red);margin-left:2px}
.form-label .opt{color:var(--ink3);font-weight:400;font-size:11px}
.form-help{font-size:11px;color:var(--ink3);margin-top:-2px}
.form-input,.form-select,.form-textarea{padding:10px 12px;font-size:13px;border:1px solid var(--ivory3);border-radius:7px;font-family:inherit;color:var(--ink);background:var(--white);outline:none;width:100%}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--amber)}
.form-textarea{resize:vertical;min-height:90px;line-height:1.55}
.form-radio-group{display:flex;flex-direction:column;gap:10px;background:var(--ivory2);border-radius:8px;padding:14px 16px}
.form-radio-group.row{flex-direction:row;flex-wrap:wrap}
.form-radio{display:flex;gap:10px;align-items:flex-start;cursor:pointer;font-size:13px;color:var(--ink)}
.form-radio input{accent-color:var(--amber);margin-top:3px;cursor:pointer}
.form-radio strong{font-weight:600}
.form-radio .sub{display:block;font-size:11px;color:var(--ink3);margin-top:2px;font-weight:400}
.form-checks{display:flex;flex-direction:column;gap:9px;background:var(--ivory2);border-radius:8px;padding:14px 16px}
.form-check{display:flex;gap:9px;align-items:center;font-size:13px;color:var(--ink);cursor:pointer}
.form-check input{accent-color:var(--amber);width:14px;height:14px;cursor:pointer}
.form-upload{border:2px dashed var(--ivory3);border-radius:10px;padding:24px;text-align:center;background:var(--ivory2);color:var(--ink2);font-size:13px}
.form-upload strong{color:var(--ink);font-weight:600}
.form-upload .sub{font-size:11px;color:var(--ink3);margin-top:4px}
.form-foot{display:flex;align-items:center;justify-content:space-between;padding-top:8px;gap:14px}
.form-foot-actions{display:flex;gap:8px}
.form-foot-note{font-size:12px;color:var(--ink3)}
.form-divider{border:0;border-top:1px solid var(--ivory3);margin:18px 0}

/* Settings page */
.settings-grid{display:grid;grid-template-columns:220px 1fr;gap:28px;align-items:flex-start}
.settings-side{position:sticky;top:74px;display:flex;flex-direction:column;gap:2px}
.settings-link{padding:9px 12px;font-size:13px;color:var(--ink2);text-decoration:none;border-radius:6px;display:flex;align-items:center;gap:9px}
.settings-link:hover{background:var(--ivory);color:var(--ink);text-decoration:none}
.settings-link.active{background:var(--white);color:var(--ink);font-weight:600;border:1px solid var(--ivory3)}
.settings-side-h{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--ink3);margin:14px 0 6px;padding:0 12px}
.settings-side-h:first-child{margin-top:0}
.toggle{position:relative;width:34px;height:20px;background:var(--ivory3);border-radius:12px;cursor:pointer;flex-shrink:0;transition:background .15s}
.toggle.on{background:var(--amber)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;background:white;border-radius:50%;transition:transform .15s;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.toggle.on::after{transform:translateX(14px)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--ivory3)}
.toggle-row:last-child{border-bottom:none}
.toggle-row-text strong{display:block;font-size:13px;color:var(--ink);font-weight:600;margin-bottom:2px}
.toggle-row-text .sub{font-size:12px;color:var(--ink2)}
.team-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--ivory3)}
.team-row:last-child{border-bottom:none}
.team-avatar{width:34px;height:34px;border-radius:50%;background:var(--amber);color:white;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.team-info{flex:1}
.team-name{font-size:13px;font-weight:600;color:var(--ink)}
.team-role{font-size:11px;color:var(--ink3)}

@media(max-width:980px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
  .appnav-search{display:none}
  .appnav-tabs .label{display:none}
  .claim-row{grid-template-columns:1fr;gap:8px}
  .claim-row .claim-cell-l{margin-top:8px}
  .form-row,.form-row.three{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}
  .settings-side{position:static;flex-direction:row;flex-wrap:wrap;overflow-x:auto}
}
