/* ============================================================
   WIN — Pełny Audyt SMM 2026
   Wino / Granat / Krem · Playfair Display + Archivo
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600&family=Archivo:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500&display=swap');

:root{
  --wine:#6B212C;
  --wine-soft:#8B3A45;
  --wine-deep:#4E1620;
  --ink:#1A1A2E;
  --ink-soft:#2D2D44;
  --ink-2:#3A3A52;
  --paper:#FBF8F3;
  --paper-2:#F3ECE0;
  --paper-3:#EDE3D3;
  --gold:#B0883E;
  --gold-soft:#C8A766;
  --line:rgba(26,26,46,0.12);
  --line-soft:rgba(26,26,46,0.07);
  --muted:#6E6A63;
  --muted-2:#928D84;

  /* content-format coded colors (muted, consistent L/C) */
  --f-story:#3E5C76;
  --f-reel:#B0562F;
  --f-post:#5C6E45;
  --f-ads:#A8812F;
  --f-live:#6E4566;
  --f-ugc:#3D7068;
  --f-shop:#8C2F2A;
  --f-rez:#2D3E5C;

  --page-w:880px;
}

*{box-sizing:border-box;margin:0;padding:0;}

html{ -webkit-text-size-adjust:100%; }

body{
  background:
    radial-gradient(1200px 700px at 50% -10%, #232338 0%, transparent 60%),
    linear-gradient(180deg,#16161f 0%,#101019 100%);
  background-attachment:fixed;
  font-family:'Archivo',system-ui,sans-serif;
  color:var(--ink);
  line-height:1.62;
  padding:40px 18px 80px;
  -webkit-font-smoothing:antialiased;
}

/* ---------- PAGE SHEET ---------- */
.page{
  max-width:var(--page-w);
  margin:0 auto;
  background:var(--paper);
  box-shadow:0 30px 80px rgba(0,0,0,.55), 0 4px 14px rgba(0,0,0,.3);
  overflow:hidden;
}
.pad{ padding:64px 72px; }
.pad-tight{ padding:46px 72px; }

/* ---------- TYPE ---------- */
h1,h2,h3,h4{ font-family:'Playfair Display',Georgia,serif; font-weight:700; color:var(--ink); line-height:1.12; letter-spacing:-.01em; }
p{ text-wrap:pretty; }
.serif{ font-family:'Playfair Display',Georgia,serif; }
.mono{ font-family:'Archivo',monospace; }

.kicker{
  font-family:'Archivo',sans-serif;
  font-size:11px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--wine);
}
.kicker.gold{ color:var(--gold); }
.kicker.muted{ color:var(--muted-2); }

.lead{ font-size:17px; line-height:1.7; color:#34323b; }
.lead.big{ font-size:19px; }
.body{ font-size:15px; color:#3a3842; }
.small{ font-size:13px; color:var(--muted); }
.tiny{ font-size:11.5px; color:var(--muted-2); }

a{ color:var(--wine); }

/* ---------- COVER ---------- */
.cover{
  position:relative;
  background:
    radial-gradient(900px 500px at 78% 8%, rgba(139,58,69,.55) 0%, transparent 55%),
    linear-gradient(150deg,#1A1A2E 0%, #241b29 42%, #54202c 100%);
  color:var(--paper);
  padding:84px 72px 70px;
  overflow:hidden;
}
.cover::after{
  content:"WIN";
  position:absolute; right:-30px; bottom:-78px;
  font-family:'Playfair Display',serif; font-weight:900; font-style:italic;
  font-size:330px; line-height:1; color:rgba(251,248,243,.045);
  letter-spacing:-.04em; pointer-events:none;
}
.cover-rule{ width:54px; height:3px; background:var(--gold); margin:0 0 30px; }
.cover .eyebrow{
  font-size:12px; font-weight:600; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold-soft); margin-bottom:26px;
}
.cover h1{
  color:var(--paper); font-weight:800;
  font-size:72px; line-height:1.02; letter-spacing:-.02em;
  max-width:13ch; margin-bottom:26px;
}
.cover h1 em{ font-style:italic; color:var(--gold-soft); font-weight:600; }
.cover .sub{
  font-size:17px; line-height:1.65; color:rgba(251,248,243,.82);
  max-width:54ch; margin-bottom:40px; position:relative; z-index:2;
}
.cover .meta{
  display:flex; flex-wrap:wrap; gap:10px 26px;
  font-size:12.5px; letter-spacing:.04em; color:rgba(251,248,243,.62);
  border-top:1px solid rgba(251,248,243,.16); padding-top:22px; position:relative; z-index:2;
}
.cover .meta b{ color:var(--gold-soft); font-weight:600; }

/* ---------- SECTION BANNER ---------- */
.banner{
  display:flex; align-items:stretch; gap:0;
  background:linear-gradient(110deg,#1A1A2E 0%, #2a1c2c 60%, #5a2330 100%);
  color:var(--paper);
  margin:0 -72px 40px;
  break-inside:avoid;
}
.banner .num{
  font-family:'Playfair Display',serif; font-weight:800; font-style:italic;
  font-size:84px; line-height:1; color:var(--gold-soft);
  padding:30px 0 30px 72px; min-width:150px;
  display:flex; align-items:center;
}
.banner .bt{ padding:26px 72px 26px 8px; display:flex; flex-direction:column; justify-content:center; }
.banner .bt .ek{ font-size:11px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:7px; }
.banner .bt h2{ color:var(--paper); font-size:30px; font-weight:700; }

/* sub-section heading */
.sub-h{ margin:44px 0 14px; }
.sub-h .n{ font-family:'Archivo',sans-serif; font-weight:700; color:var(--wine); font-size:14px; letter-spacing:.04em; }
.sub-h h3{ font-size:24px; margin-top:4px; }
.sub-h.tight{ margin-top:34px; }

h4.blockh{ font-size:18px; margin:30px 0 12px; color:var(--wine); }

.divider{ height:1px; background:var(--line); margin:40px 0; }
.divider.wine{ height:2px; background:linear-gradient(90deg,var(--wine),transparent); }

/* ---------- KPI DASHBOARD ---------- */
.kpi-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin:8px 0; }
.kpi{ background:var(--paper); padding:18px 16px 16px; }
.kpi .v{ font-family:'Playfair Display',serif; font-weight:700; font-size:33px; color:var(--ink); line-height:1; letter-spacing:-.02em; }
.kpi .v.neg{ color:var(--wine); }
.kpi .v.pos{ color:var(--f-post); }
.kpi .l{ font-size:12px; font-weight:600; color:var(--ink); margin-top:8px; }
.kpi .s{ font-size:11px; color:var(--muted-2); margin-top:3px; line-height:1.4; }

/* ---------- NORTH STAR / FEATURE RIBBON ---------- */
.ribbon{
  background:linear-gradient(120deg,#1A1A2E,#3a2230);
  color:var(--paper); padding:24px 28px; display:flex; gap:18px; align-items:flex-start;
  margin:26px 0; break-inside:avoid;
}
.ribbon .ic{ font-size:22px; line-height:1.2; }
.ribbon .tx{ font-size:15px; line-height:1.6; color:rgba(251,248,243,.9); }
.ribbon .tx b{ color:var(--gold-soft); font-weight:600; }
.ribbon.gold{ background:linear-gradient(120deg,#5a3c10,#7a5418); }

/* ---------- CALLOUTS ---------- */
.callout{ padding:16px 20px 16px 18px; margin:22px 0; font-size:14px; line-height:1.6; border-left:3px solid var(--muted); background:var(--paper-2); break-inside:avoid; }
.callout .h{ font-weight:700; }
.callout.warn{ border-color:var(--wine); background:#f6ece6; color:#52131a; }
.callout.warn .h, .callout.warn strong{ color:var(--wine); }
.callout.arrow{ border-color:var(--ink); background:var(--paper-2); }
.callout.arrow strong{ color:var(--ink); }
.callout.tip{ border-color:var(--gold); background:#f7efdd; color:#5a4413; }
.callout.tip strong{ color:#7a5613; }
.callout.ok{ border-color:var(--f-post); background:#eef1e6; color:#3a4527; }
.callout em{ font-style:italic; }
.callout .ico{ font-style:normal; margin-right:7px; }

/* ---------- DATA TABLE ---------- */
.tbl-wrap{ margin:20px 0; border:1px solid var(--line); overflow:hidden; }
table.data{ width:100%; border-collapse:collapse; font-size:13px; }
table.data thead th{
  background:var(--ink); color:var(--paper); text-align:left;
  font-family:'Archivo',sans-serif; font-weight:600; font-size:11px; letter-spacing:.07em; text-transform:uppercase;
  padding:11px 14px; vertical-align:middle;
}
table.data td{ padding:10px 14px; border-top:1px solid var(--line); vertical-align:top; color:#3a3842; }
table.data tbody tr:nth-child(even){ background:var(--paper-2); }
table.data td.num, table.data th.num{ font-variant-numeric:tabular-nums; white-space:nowrap; }
table.data .star{ color:var(--gold); font-weight:700; }
table.data .up{ color:var(--f-post); font-weight:600; }
table.data .down{ color:var(--wine); font-weight:600; }
table.data .lead-col{ font-weight:600; color:var(--ink); }
table.data tr.warn-row td{ background:#f6ece6; }
table.data tr.warn-row td:first-child{ box-shadow:inset 3px 0 0 var(--wine); }
.t-cap{ font-size:11.5px; color:var(--muted-2); font-style:italic; margin:8px 2px 0; }

/* compact 2-col framing table reused */
table.data.tight td, table.data.tight th{ padding:9px 12px; }

/* ---------- TWO-COL & CARDS ---------- */
.cols-2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:20px 0; }
.cols-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin:20px 0; }
.card{ background:var(--paper); border:1px solid var(--line); padding:20px 22px; break-inside:avoid; }
.card.shade{ background:var(--paper-2); }
.card h4{ font-size:17px; color:var(--ink); margin-bottom:8px; }
.card .ct{ font-size:13.5px; color:#46434c; line-height:1.55; }

/* bar/barrier blocks */
.barrier{ border:1px solid var(--line); border-top:3px solid var(--wine); background:var(--paper); margin:18px 0; break-inside:avoid; }
.barrier .bh{ background:var(--ink); color:var(--paper); padding:13px 22px; font-family:'Playfair Display',serif; font-weight:700; font-size:18px; }
.barrier .bh .tag{ font-family:'Archivo'; font-size:11px; font-weight:600; letter-spacing:.14em; color:var(--gold-soft); display:block; margin-bottom:2px; text-transform:uppercase; }
.barrier .bb{ padding:18px 22px; }
.barrier .row{ margin-bottom:14px; }
.barrier .row:last-child{ margin-bottom:0; }
.barrier .lab{ font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--wine); margin-bottom:4px; }
.barrier .lab.fix{ color:var(--f-post); }
.barrier .tx{ font-size:13.5px; color:#46434c; line-height:1.55; }
.barrier .quote{ font-style:italic; color:var(--ink-soft); }

/* lists */
ul.clean{ list-style:none; margin:14px 0; }
ul.clean li{ position:relative; padding-left:24px; margin-bottom:10px; font-size:14px; color:#3a3842; line-height:1.55; }
ul.clean li::before{ content:"—"; position:absolute; left:0; color:var(--wine); font-weight:700; }
ul.check li::before{ content:"✓"; color:var(--f-post); }
ul.cross li::before{ content:"✗"; color:var(--wine); }
ul.arrow-li li::before{ content:"→"; color:var(--gold); }

/* do/don't split */
.dd{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:22px 0; }
.dd .box{ padding:20px 22px; border:1px solid var(--line); break-inside:avoid; }
.dd .box.no{ background:#f6ece6; border-color:#e0c4bd; }
.dd .box.yes{ background:#eef1e6; border-color:#cdd6bb; }
.dd .box h4{ font-size:15px; margin-bottom:12px; }
.dd .box.no h4{ color:var(--wine); }
.dd .box.yes h4{ color:#46562c; }
.dd .box ul.clean li{ font-size:13px; margin-bottom:8px; }

/* copy snippet block (ready captions) */
.snippet{ background:var(--ink); color:var(--paper); padding:16px 20px; margin:12px 0; }
.snippet .sl{ font-size:10.5px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:7px; }
.snippet .st{ font-size:14.5px; line-height:1.55; color:#f0ece4; font-style:italic; }

/* ---------- FIGURE (recreated schema) ---------- */
.figure{ margin:30px -10px; border:1px solid var(--line); background:#fff; break-inside:avoid; }
.figure .fcap-top{ display:flex; align-items:center; justify-content:space-between; gap:14px; background:var(--paper-2); border-bottom:1px solid var(--line); padding:13px 20px; }
.figure .fcap-top .ft{ font-family:'Playfair Display',serif; font-weight:700; font-size:17px; color:var(--ink); }
.figure .fcap-top .fk{ font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); }
.figure .fbody{ padding:22px 20px; }
.figure .fcap{ font-size:11.5px; color:var(--muted-2); font-style:italic; padding:0 20px 16px; }

/* pills (content formats) */
.pill{ display:inline-block; border-radius:2px; padding:2px 7px; font-size:10px; font-weight:700; letter-spacing:.03em; color:#fff; margin:0 3px 3px 0; }
.p-story{ background:var(--f-story); } .p-reel{ background:var(--f-reel); }
.p-post{ background:var(--f-post); } .p-ads{ background:var(--f-ads); }
.p-live{ background:var(--f-live); } .p-ugc{ background:var(--f-ugc); }
.p-shop{ background:var(--f-shop); } .p-rez{ background:var(--f-rez); }

/* tabs */
.tabs{ display:flex; flex-wrap:wrap; gap:7px; margin-bottom:16px; }
.tab{ font-family:'Archivo',sans-serif; font-size:12px; font-weight:600; padding:7px 15px; border:1px solid var(--line); background:var(--paper); color:var(--muted); cursor:pointer; transition:.15s; border-radius:2px; white-space:nowrap; }
.tab:hover{ color:var(--ink); }
.tab.on{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.tview{ display:none; }
.tview.on{ display:block; }
.thint{ margin-left:auto; align-self:center; font-size:10.5px; font-style:italic; color:var(--muted-2); white-space:nowrap; }
.thint::before{ content:"☞ "; font-style:normal; color:var(--gold); }

/* timeline / day grid building blocks */
.tlgrid{ display:grid; gap:0; border:1px solid var(--line); overflow:hidden; }
.tl-h{ font-size:10px; font-weight:700; color:#fff; padding:7px 5px; text-align:center; line-height:1.25; letter-spacing:.02em; }
.tl-h .w{ font-weight:400; font-size:8.5px; opacity:.85; }
.tl-b{ padding:8px 7px; font-size:10.5px; line-height:1.42; border-top:1px solid var(--line); border-left:1px solid var(--line-soft); min-height:80px; color:#3a3842; }
.tl-b:first-child{ border-left:none; }
.tl-note{ font-size:10.5px; color:#46434c; margin-top:1px; }
.tl-tag{ font-size:9.5px; font-weight:700; padding:2px 5px; border-radius:2px; margin-top:4px; display:inline-block; }
.note-shop{ font-size:10px; color:var(--f-shop); font-weight:600; margin-top:4px; background:#f7eae7; border-radius:2px; padding:3px 6px; }
.note-rez{ font-size:10px; color:var(--f-rez); font-weight:600; margin-top:4px; background:#e9edf3; border-radius:2px; padding:3px 6px; }
.note-guest{ font-size:10px; color:var(--f-live); font-weight:600; margin-top:4px; background:#f2eaf1; border-radius:2px; padding:3px 6px; }
.ads-label{ font-size:9.5px; color:var(--gold); font-weight:700; margin-top:5px; border-top:1px dashed #e3d4ad; padding-top:4px; }

/* phase strip */
.strip{ display:flex; border-radius:2px; overflow:hidden; margin-bottom:12px; font-size:10px; font-weight:700; }
.strip > div{ text-align:center; padding:6px 5px; color:#fff; display:flex; align-items:center; justify-content:center; line-height:1.25; }

/* flow map (strategy) */
.flow-label{ font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--muted-2); margin:0 0 8px 1px; }
.flow-row{ display:flex; gap:9px; }
.flow-row > div{ flex:1; border-radius:3px; padding:11px 9px; text-align:center; }
.seg{ color:#fff; }
.seg .sn{ font-size:13px; font-weight:700; font-family:'Playfair Display',serif; }
.seg .sw{ font-size:10px; opacity:.85; margin-top:2px; }
.flow-arrow{ text-align:center; color:var(--line); font-size:11px; padding:5px 0; }
.offer{ background:var(--paper-2); border:1px solid var(--line); font-size:11px; color:#46434c; }
.offer .on{ font-weight:700; font-size:12px; color:var(--ink); font-family:'Playfair Display',serif; }
.offer .op{ font-size:11px; color:var(--gold); font-weight:600; margin-top:2px; }
.pillar{ border:1px solid; border-radius:3px; padding:10px 7px; }
.pillar .pn{ font-size:12px; font-weight:700; }
.pillar .pnote{ font-size:10px; margin-top:3px; opacity:.85; }

/* month columns */
.mcols{ display:flex; gap:10px; }
.mcol{ flex:1; border:1px solid var(--line); overflow:hidden; border-radius:3px; }
.mcol .mh{ padding:9px 10px; font-size:12px; font-weight:700; color:#fff; text-align:center; font-family:'Playfair Display',serif; }
.mcol .mh span{ font-family:'Archivo'; font-weight:400; font-size:10px; display:block; opacity:.9; margin-top:2px; }
.mcol .mb{ padding:10px; display:flex; flex-direction:column; gap:7px; }
.mseg{ background:var(--paper-2); border-radius:3px; padding:7px 9px; }
.mseg .ml{ font-size:10px; font-weight:700; letter-spacing:.05em; color:var(--ink); text-transform:uppercase; margin-bottom:5px; }
.chips{ display:flex; flex-wrap:wrap; gap:4px; }
.chip{ font-size:10.5px; padding:3px 8px; border-radius:2px; font-weight:600; background:#e9e2d4; color:#5a4a2e; }

/* monthly calendar */
.cal{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.cal .cd{ border-radius:3px; padding:6px; min-height:62px; font-size:10px; background:var(--paper-2); }
.cal .cd .cn{ font-weight:700; font-size:11px; margin-bottom:3px; font-family:'Playfair Display',serif; }
.cal .cd.empty{ background:#f6f2ea; }
.cal .ch{ text-align:center; font-size:10px; font-weight:700; color:var(--muted-2); padding:2px; letter-spacing:.05em; }
.ctag{ display:inline-block; font-size:8.5px; font-weight:700; padding:1px 5px; border-radius:2px; margin-top:2px; }

.legend{ display:flex; flex-wrap:wrap; gap:9px 14px; margin-top:14px; padding-top:12px; border-top:1px solid var(--line); }
.leg{ display:flex; align-items:center; gap:6px; font-size:11px; color:var(--muted); }
.leg .dot{ width:11px; height:11px; border-radius:2px; }

/* guest-need columns */
.gneed{ border:1px solid var(--line); border-radius:3px; overflow:hidden; }
.gneed .gh{ color:#fff; padding:11px 16px; font-family:'Playfair Display',serif; font-weight:700; font-size:15px; }
.gneed .gh span{ font-family:'Archivo'; font-weight:400; font-size:11px; display:block; opacity:.9; margin-top:2px; }
.gneed .gb{ padding:14px 16px; font-size:12.5px; }
.gneed .gl{ font-weight:700; margin:6px 0 5px; }
.gneed .qbox{ padding:9px 11px; border-radius:3px; font-style:italic; font-size:12.5px; line-height:1.5; }

/* image placeholder (screenshots referenced in audit) */
.shot{
  border:1px solid var(--line);
  background:repeating-linear-gradient(135deg, var(--paper-2) 0 11px, var(--paper-3) 11px 22px);
  min-height:120px; display:flex; align-items:center; justify-content:center; text-align:center;
  padding:22px; margin:18px 0; break-inside:avoid;
}
.shot .lbl{ font-family:'Archivo',monospace; font-size:11px; letter-spacing:.06em; color:var(--muted); max-width:46ch; line-height:1.5; }
.shot .lbl b{ display:block; font-weight:700; color:var(--wine); letter-spacing:.14em; text-transform:uppercase; font-size:10px; margin-bottom:6px; }
.shot.tall{ min-height:170px; }

/* series library */
.series{ border:1px solid var(--line); margin:14px 0; break-inside:avoid; }
.series .sh{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap; background:var(--ink); color:var(--paper); padding:12px 18px; }
.series .sh .sn{ font-family:'Playfair Display',serif; font-weight:700; font-size:17px; }
.series .sh .sm{ font-size:10.5px; letter-spacing:.04em; color:rgba(251,248,243,.62); }
.series .prio{ font-size:10px; font-weight:700; letter-spacing:.08em; padding:3px 9px; border-radius:2px; white-space:nowrap; }
.series .prio.p1{ background:var(--gold); color:#2a1c08; }
.series .prio.p2{ background:#5a6e45; color:#fff; }
.series .prio.p3{ background:var(--ink-2); color:var(--gold-soft); }
.series .sb{ padding:16px 18px; }
.series .sb .concept{ font-size:13.5px; color:#46434c; line-height:1.55; margin-bottom:10px; }
.series .insight{ background:#f7efdd; border-left:3px solid var(--gold); padding:9px 13px; font-size:12.5px; color:#5a4413; margin-top:12px; line-height:1.5; }

/* real image figures */
.imgfig{ margin:24px 0; break-inside:avoid; }
.imgfig img{ display:block; width:100%; height:auto; border:1px solid var(--line); }
.imgcap{ font-size:11.5px; color:var(--muted-2); font-style:italic; margin:9px 2px 0; line-height:1.5; }
.imgcap b{ color:var(--wine); font-style:normal; font-weight:700; letter-spacing:.04em; }

.phonerow{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; align-items:flex-start; background:var(--paper-2); border:1px solid var(--line); padding:22px 20px; }
.phonerow img{ height:336px; width:auto; max-width:100%; border-radius:16px; border:1px solid rgba(26,26,46,.18); box-shadow:0 10px 28px rgba(26,26,46,.16); background:#fff; }
.phonerow.sm img{ height:288px; }

.reelgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin:22px 0; }
.reelcard{ border:1px solid var(--line); background:var(--paper-2); padding:14px 14px 16px; break-inside:avoid; display:flex; flex-direction:column; }
.reelcard img{ width:100%; height:300px; object-fit:cover; object-position:top center; border-radius:12px; box-shadow:0 6px 18px rgba(26,26,46,.16); }
.reelcard .rc{ font-size:12px; color:#46434c; margin-top:11px; line-height:1.5; }
.reelcard .rc b{ color:var(--wine); display:block; margin-bottom:3px; font-size:11.5px; }

@media (max-width:760px){
  .reelgrid{ grid-template-columns:repeat(2,1fr); }
  .phonerow img{ height:260px; }
}

/* footer */
.foot{ background:var(--ink); color:rgba(251,248,243,.6); padding:30px 72px; font-size:12px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.foot b{ color:var(--gold-soft); font-weight:600; }

/* phase plan cards (90 days) */
.phase{ border:1px solid var(--line); break-inside:avoid; }
.phase .ph{ background:linear-gradient(110deg,var(--wine),var(--wine-soft)); color:#fff; padding:14px 20px; }
.phase .ph .pk{ font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft); }
.phase .ph h4{ color:#fff; font-size:21px; margin-top:2px; }
.phase .pb{ padding:16px 20px; }

/* responsive */
@media (max-width:760px){
  .pad,.pad-tight{ padding:40px 26px; }
  .cover{ padding:56px 28px 48px; }
  .cover h1{ font-size:48px; }
  .banner{ margin:0 -26px 32px; }
  .banner .num{ padding-left:26px; min-width:96px; font-size:58px; }
  .banner .bt{ padding:20px 26px 20px 6px; }
  .banner .bt h2{ font-size:22px; }
  .kpi-grid{ grid-template-columns:repeat(2,1fr); }
  .cols-2,.cols-3,.dd,.tlgrid{ grid-template-columns:1fr !important; }
  .mcols{ flex-direction:column; }
  .foot{ padding:24px 26px; }
  .figure{ margin:24px 0; }
  .tl-b{ min-height:0; }
}

/* ============ PRINT / A4 ============ */
@media print{
  @page{ size:A4; margin:13mm 12mm; }
  body{ background:#fff; padding:0; }
  .page{ max-width:none; box-shadow:none; }
  .pad,.pad-tight{ padding:0; }
  .cover{ padding:38mm 16mm; min-height:auto; -webkit-print-color-adjust:exact; print-color-adjust:exact; page-break-after:always; }
  .cover::after{ font-size:200px; bottom:-40px; }
  .banner{ margin:0 0 22px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  .part{ page-break-before:always; padding:0; }
  .part:first-of-type{ page-break-before:avoid; }
  .banner,.barrier,.callout,.ribbon,.card,.figure,.kpi-grid,.tbl-wrap,.phase,table.data tr{ page-break-inside:avoid; }
  table.data thead th{ -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  *{ -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  /* expand all tabbed figures for print */
  .tabs{ display:none; }
  .tview{ display:block !important; margin-bottom:18px; }
  .tview + .tview{ border-top:1px dashed var(--line); padding-top:16px; }
  .foot{ -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  h2,h3,h4{ page-break-after:avoid; }
}
