/* ============================================================
   Tatiana Vaccaro — Official Press Kit 2027
   Monochrome editorial. Black / White / Silver only.
   (Colour appears solely in the photography.)
   Type system matches TatianaVaccaro.com:
   Bodoni Moda · Josefin Sans · Cormorant Garamond
   Each .sheet is a fixed US Letter page (8.5 x 11in).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6,400;0,6,500;0,6,600;0,72,400;0,72,500;0,72,700;0,72,900;1,6,400;1,72,400;1,72,500&family=Josefin+Sans:wght@100;200;300;400;500&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&display=swap');

:root{
  --black:#0C0C0C;       /* dark page background */
  --charcoal:#1A1A1A;    /* primary ink */
  --ink:#1A1A1A;
  --paper:#FFFFFF;       /* light page background */
  --silver:#D0D0D0;      /* accent on dark */
  --silver-2:#BFBFBF;
  --gray:#999999;        /* labels / fine detail */
  --mid:#666666;
  --line-l:rgba(0,0,0,.13);
  --line-d:rgba(255,255,255,.22);
  --serif:'Bodoni Moda', Georgia, serif;
  --script:'Cormorant Garamond', Georgia, serif;
  --sans:'Josefin Sans', 'Helvetica Neue', Arial, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; -webkit-print-color-adjust:exact; print-color-adjust:exact; }

html,body{ background:#2b2b2b; }
body{
  font-family:var(--sans);
  color:var(--ink);
  font-optical-sizing:auto;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ---------- The sheet ---------- */
.sheet{
  position:relative;
  width:8.5in;
  height:11in;
  background:var(--paper);
  overflow:hidden;
  page-break-after:always;
  break-after:page;
}
.sheet:last-child{ page-break-after:auto; break-after:auto; }

@media screen{
  .deck{ padding:120px 0 80px; }
  .sheet{ margin:0 auto 34px; box-shadow:0 24px 70px rgba(0,0,0,.5); }
}

/* ---------- shared type ---------- */
.label{
  font-family:var(--sans);
  font-weight:300;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-size:11px;
  color:var(--gray);
}
h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.04; font-optical-sizing:auto; }
.display{ font-family:var(--serif); }
.script{ font-family:var(--script); }

.rule-gold{ height:1px; background:var(--line-l); border:0; }

/* page footer */
.footer{
  position:absolute; left:0.7in; right:0.7in; bottom:0.42in;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--sans); font-weight:300; font-size:9px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--gray);
}
.footer .pg{ color:var(--mid); }

/* ============================================================
   PAGE 1 — COVER
   ============================================================ */
.cover{ background:var(--black); }
.cover .bg{
  position:absolute; inset:0;
  background-size:cover; background-position:50% 30%;
}
.cover .scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,8,8,.5) 0%, rgba(8,8,8,0) 26%),
    linear-gradient(0deg, rgba(6,6,6,.94) 0%, rgba(6,6,6,.55) 26%, rgba(6,6,6,0) 52%);
}
.cover .topbar{
  position:absolute; top:0.62in; left:0.7in; right:0.7in;
  display:flex; justify-content:space-between; align-items:center;
}
.cover .topbar .label{ color:var(--silver); }
.cover .topbar .mark{
  font-family:var(--script); font-style:italic; font-size:18px; color:var(--silver);
  letter-spacing:.02em;
}
.cover .cap{
  position:absolute; left:0.7in; right:0.7in; bottom:0.95in; text-align:center; color:#fff;
}
.cover .cap .name{
  font-family:var(--serif); font-weight:600; font-size:64px; line-height:1;
  letter-spacing:.01em; text-shadow:0 2px 30px rgba(0,0,0,.55);
}
.cover .cap .sub{
  font-family:var(--script); font-style:italic; font-weight:500; font-size:31px;
  color:var(--silver); margin-top:10px; letter-spacing:.02em;
}
.cover .cap .divline{ width:64px; height:1px; background:var(--silver); margin:20px auto 16px; opacity:.85; }
.cover .cap .foot{
  font-family:var(--sans); font-weight:300; font-size:10.5px; letter-spacing:.24em;
  text-transform:uppercase; color:rgba(255,255,255,.88);
}

/* ============================================================
   PAGE 2 — BIOGRAPHY
   ============================================================ */
.bio{ display:flex; }
.bio .col-img{ width:3.5in; flex:0 0 3.5in; position:relative; background:var(--black); }
.bio .col-img .ph{ position:absolute; inset:0; background-size:cover; background-position:50% 30%; }
.bio .col-img .edge{ position:absolute; top:0; right:0; bottom:0; width:5px; background:var(--charcoal); }
.bio .col-txt{ flex:1; padding:0.85in 0.62in 0.5in 0.55in; display:flex; flex-direction:column; }
.bio .label{ margin-bottom:14px; }
.bio h2{ font-size:34px; color:var(--ink); font-weight:600; }
.bio .uline{ width:54px; height:2px; background:var(--charcoal); margin:14px 0 18px; }
.bio p{ font-size:11px; line-height:1.74; color:#2a2a2a; font-weight:300; margin-bottom:10px; }
.bio .pullquote{
  margin-top:auto; padding-top:18px;
  font-family:var(--script); font-style:italic; font-weight:500; font-size:27px;
  color:var(--ink); line-height:1.2; text-align:center;
}
.bio .pullquote .pq-rule{ width:40px; height:1px; background:var(--gray); margin:0 auto 14px; }

/* ============================================================
   PAGE 3 — FAST FACTS
   ============================================================ */
.facts{ padding:0.9in 0.9in 0.9in; }
.facts .label{ margin-bottom:12px; }
.facts h2{ font-size:40px; color:var(--ink); font-weight:600; }
.facts .uline{ width:54px; height:2px; background:var(--charcoal); margin:14px 0 26px; }
.facts .row{ display:flex; align-items:baseline; padding:9px 0; border-bottom:1px solid var(--line-l); }
.facts .row .k{
  flex:0 0 2.5in; font-family:var(--sans); font-weight:400; font-size:9.5px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--gray);
}
.facts .row .v{ flex:1; font-family:var(--serif); font-weight:400; font-size:13px; color:var(--ink); }

/* ============================================================
   PAGE 4 — ACHIEVEMENTS
   ============================================================ */
.ach{ display:flex; }
.ach .col-txt{ flex:1; padding:0.85in 0.45in 0.5in 0.85in; }
.ach .col-img{ flex:0 0 3.05in; position:relative; background:var(--black); }
.ach .col-img .ph{ position:absolute; inset:0; background-size:cover; background-position:60% 50%; }
.ach .col-img .edge{ position:absolute; top:0; left:0; bottom:0; width:5px; background:var(--charcoal); }
.ach .label{ margin-bottom:12px; }
.ach h2{ font-size:32px; color:var(--ink); font-weight:600; }
.ach .uline{ width:54px; height:2px; background:var(--charcoal); margin:13px 0 20px; }
.ach .grp{ margin-bottom:18px; }
.ach .grp h3{
  font-family:var(--script); font-style:italic; font-weight:600; font-size:22px;
  color:var(--ink); margin-bottom:9px;
}
.ach .ev{ margin-bottom:8px; }
.ach .ev .t{ font-family:var(--serif); font-size:12.5px; color:var(--ink); font-weight:600; }
.ach .ev .d{ font-size:10px; color:#555; font-weight:300; line-height:1.5; }
.ach ul{ list-style:none; }
.ach ul li{ font-size:10.5px; color:#2a2a2a; font-weight:300; line-height:1.4; padding:3px 0 3px 16px; position:relative; }
.ach ul li::before{ content:''; position:absolute; left:0; top:9px; width:5px; height:5px; background:var(--charcoal); transform:rotate(45deg); }
.ach .disc{ font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray); margin-top:4px; }

/* ============================================================
   PAGE 5 — PLATFORM (full bleed + black overlay)
   ============================================================ */
.platform{ background:var(--black); }
.platform .bg{ position:absolute; inset:0; background-size:cover; background-position:50% 30%; }
.platform .scrim{ position:absolute; inset:0; background:rgba(10,10,10,.80); }
.platform .wrap{
  position:absolute; inset:0; padding:1.05in 0.95in; color:#fff;
  display:flex; flex-direction:column; text-align:center; align-items:center;
}
.platform .label{ color:var(--silver); }
.platform h2{ font-size:44px; margin:16px 0 8px; font-weight:600; color:#fff; }
.platform .divline{ width:60px; height:1px; background:var(--silver); margin:8px auto 20px; }
.platform .statement{
  font-family:var(--script); font-style:italic; font-size:22px; line-height:1.45;
  color:#ececec; max-width:5.6in; margin:0 auto;
}
.platform .grid{ margin:34px auto 0; display:grid; grid-template-columns:1fr 1fr; gap:20px 26px; max-width:5.9in; }
.platform .pillar{ border-top:1px solid var(--line-d); padding-top:12px; text-align:left; }
.platform .pillar .n{ font-family:var(--script); font-style:italic; color:var(--silver); font-size:19px; }
.platform .pillar p{ font-size:11px; font-weight:300; line-height:1.55; color:#e4e4e4; margin-top:3px; }
.platform .closing{ margin-top:auto; font-size:11px; font-weight:300; line-height:1.6; color:#bdbdbd; max-width:5.4in; letter-spacing:.02em; }

/* ============================================================
   PAGE 6 — TALKING POINTS
   ============================================================ */
.talk{ padding:0.9in 0.9in 0.9in; }
.talk .label{ margin-bottom:12px; }
.talk h2{ font-size:38px; color:var(--ink); font-weight:600; }
.talk .uline{ width:54px; height:2px; background:var(--charcoal); margin:13px 0 12px; }
.talk .intro{ font-family:var(--script); font-style:italic; font-size:17px; color:var(--mid); margin-bottom:16px; }
.talk .tp{ display:flex; gap:16px; padding:9px 0; border-bottom:1px solid var(--line-l); }
.talk .tp:last-child{ border-bottom:0; }
.talk .tp .num{ flex:0 0 auto; font-family:var(--serif); font-weight:600; font-size:23px; color:var(--ink); width:44px; line-height:1.1; }
.talk .tp p{ font-size:10.5px; line-height:1.6; color:#2a2a2a; font-weight:300; }

/* ============================================================
   PAGE 7 — MEDIA & CONTACT
   ============================================================ */
.contact{ display:flex; }
.contact .col-img{ flex:0 0 3.3in; position:relative; background:var(--black); }
.contact .col-img .ph{ position:absolute; inset:0; background-size:cover; background-position:50% 32%; }
.contact .col-img .edge{ position:absolute; top:0; right:0; bottom:0; width:5px; background:var(--charcoal); }
.contact .col-txt{ flex:1; padding:0.9in 0.62in 0.6in 0.6in; display:flex; flex-direction:column; }
.contact .label{ margin-bottom:12px; }
.contact h2{ font-size:34px; color:var(--ink); font-weight:600; }
.contact .uline{ width:54px; height:2px; background:var(--charcoal); margin:13px 0 22px; }
.contact .cblock{ margin-bottom:15px; }
.contact .cblock .k{ font-family:var(--sans); font-weight:400; font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--gray); }
.contact .cblock .v{ font-family:var(--serif); font-size:13px; color:var(--ink); margin-top:2px; }
.contact .cblock .ph-note{ font-size:10px; font-style:italic; color:#8b8b8b; font-weight:300; }
.contact .avail-h{ font-family:var(--script); font-style:italic; font-size:19px; color:var(--ink); margin:6px 0 8px; }
.contact ul{ list-style:none; }
.contact ul li{ font-size:10.5px; color:#2a2a2a; font-weight:300; padding:3px 0 3px 16px; position:relative; }
.contact ul li::before{ content:''; position:absolute; left:0; top:8px; width:5px; height:5px; background:var(--charcoal); transform:rotate(45deg); }
.contact .closing{ margin-top:auto; padding-top:14px; font-size:10px; font-weight:300; font-style:italic; color:var(--mid); line-height:1.6; }
.contact .footer{ left:3.55in; }

/* ============================================================
   PAGE 8 — BACK COVER
   ============================================================ */
.back{ background:var(--black); }
.back .wrap{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:1in; }
.back .frame{ position:absolute; inset:0.5in; border:1px solid var(--line-d); }
.back .wm{ font-family:var(--serif); font-weight:600; font-size:52px; color:#fff; letter-spacing:.01em; }
.back .ttl{ font-family:var(--script); font-style:italic; font-size:27px; color:#e6e6e6; margin-top:8px; }
.back .divline{ width:70px; height:1px; background:var(--silver); margin:26px auto; opacity:.85; }
.back .tag{ font-family:var(--sans); font-weight:300; font-size:10.5px; letter-spacing:.26em; text-transform:uppercase; color:var(--silver-2); }
.back .web{ font-family:var(--sans); font-weight:300; font-size:11px; letter-spacing:.14em; color:#fff; margin-top:18px; }
.back .mgd{ position:absolute; bottom:0.85in; left:0; right:0; text-align:center; font-family:var(--sans); font-weight:300; font-size:8.5px; letter-spacing:.3em; text-transform:uppercase; color:var(--gray); }

/* ============================================================
   SCREEN-ONLY: download toolbar + asset strip
   ============================================================ */
.toolbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(10,10,10,.93); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line-d);
  display:flex; align-items:center; justify-content:space-between; padding:14px 26px;
}
.toolbar .brand .n{ font-family:var(--serif); font-size:17px; color:#fff; }
.toolbar .brand .t{ font-family:var(--sans); font-weight:300; font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-top:2px; }
.toolbar .actions{ display:flex; gap:10px; align-items:center; }
.btn-gold{
  font-family:var(--sans); font-weight:400; font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:#111; background:linear-gradient(180deg,#ffffff,#e6e6e6);
  padding:12px 22px; border-radius:2px; text-decoration:none; border:0; cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.4);
}
.btn-gold:hover{ filter:brightness(1.04); }
.btn-ghost{
  font-family:var(--sans); font-weight:300; font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--silver); border:1px solid rgba(255,255,255,.4); padding:11px 18px; border-radius:2px; text-decoration:none;
}
.btn-ghost:hover{ background:rgba(255,255,255,.1); color:#fff; }

.assets{ max-width:8.5in; margin:10px auto 90px; padding:0 12px; }
.assets h3{ font-family:var(--sans); font-weight:300; letter-spacing:.3em; text-transform:uppercase; font-size:11px; color:var(--silver); text-align:center; margin-bottom:18px; }
.assets .grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.assets a.card{ display:block; text-decoration:none; background:#161616; border:1px solid rgba(255,255,255,.16); border-radius:3px; overflow:hidden; }
.assets a.card img{ width:100%; height:150px; object-fit:cover; display:block; }
.assets a.card .cap{ display:flex; justify-content:space-between; align-items:center; padding:10px 12px; font-family:var(--sans); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#cfcfcf; }
.assets a.card .cap .dl{ color:#fff; font-weight:400; }
.assets a.card:hover{ border-color:rgba(255,255,255,.55); }

.screen-only{ display:block; }

@media print{
  html,body{ background:#fff; }
  .toolbar,.assets,.screen-only{ display:none !important; }
  .deck{ padding:0 !important; }
  .sheet{ margin:0 !important; box-shadow:none !important; }
}
@page{ size:Letter; margin:0; }
