/* ============================================================
   costandprofitability.com - CostCtrl demo launcher
   Reusable teaser that opens the live demo in a NEW TAB.
   Praxis. Scoped .cc-demo. Two layouts: .band (hero/product/home)
   and .card (inline, end of article). Data-driven (window.CC_DEMO).
   Never blue. EN / PT-PT / ES-ES.
   ============================================================ */
.cc-demo{
  --o:#C75B22; --o-br:#E2761A; --grn:#1C7A57; --grn-soft:#3E9B74; --info:#2B6CB0;
  --ink:#1A1714; --ink2:#4A4138; --muted:#756859; --muted2:#9A8E7E;
  --paper:#F3EEE4; --paper2:#EDE6D8; --surface:#FBF9F3; --surface2:#FAF7F0;
  --line:#DCD3C2; --line2:#C9BEAA; --dark:#14110D; --red:#B23A2E; --wheat:#E8DBC2;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --serif:'Newsreader',Georgia,serif;
  --sans:'Hanken Grotesk',system-ui,sans-serif;
  font-family:var(--sans);color:var(--ink);-webkit-font-smoothing:antialiased;
}
.cc-demo *{box-sizing:border-box;}
.cc-demo a.dm-root{text-decoration:none;color:inherit;display:block;}

/* ---------- shared mini-preview (the little dashboard) ---------- */
.cc-demo .dm-prev{background:var(--dark);border-radius:12px;padding:14px;position:relative;overflow:hidden;border:1px solid #2a241d;}
.cc-demo .dm-prev::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(199,91,34,.25),transparent 70%);pointer-events:none;}
.cc-demo .dm-bar{display:flex;align-items:center;gap:6px;margin-bottom:11px;}
.cc-demo .dm-bar i{width:8px;height:8px;border-radius:50%;background:#3a3128;display:block;}
.cc-demo .dm-bar i:first-child{background:var(--o);}
.cc-demo .dm-bar .dm-title{margin-left:8px;font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--wheat);}
.cc-demo .dm-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:9px;}
.cc-demo .dm-kpi{background:#1f1a14;border-radius:6px;padding:7px 8px;}
.cc-demo .dm-kpi .l{font-family:var(--mono);font-size:6.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted2);margin-bottom:3px;}
.cc-demo .dm-kpi .v{font-family:var(--serif);font-size:14px;color:#fff;line-height:1;}
.cc-demo .dm-kpi .v.pos{color:var(--grn-soft);}
.cc-demo .dm-kpi .v.neg{color:#E08577;}
.cc-demo .dm-chart{background:#1f1a14;border-radius:6px;padding:9px;}
.cc-demo .dm-chart svg{width:100%;height:auto;display:block;}

/* play / launch chip on the preview */
.cc-demo .dm-launch{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;
  display:flex;align-items:center;gap:8px;background:rgba(20,17,13,.78);backdrop-filter:blur(3px);
  border:1px solid rgba(232,219,194,.3);border-radius:100px;padding:9px 15px;opacity:0;transition:opacity .18s;}
.cc-demo .dm-launch svg{width:14px;height:14px;}
.cc-demo .dm-launch span{font-family:var(--sans);font-weight:600;font-size:12px;color:#fff;}

/* ---------- BAND layout ---------- */
.cc-demo.band a.dm-root{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;
  display:grid;grid-template-columns:1.05fr 1fr;gap:28px;align-items:center;transition:border-color .16s,box-shadow .16s,transform .16s;}
.cc-demo.band a.dm-root:hover{border-color:var(--o);box-shadow:0 18px 40px -22px rgba(199,91,34,.5);transform:translateY(-2px);}
.cc-demo.band a.dm-root:hover .dm-launch{opacity:1;}
.cc-demo.band .dm-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--o);display:flex;align-items:center;gap:9px;margin-bottom:13px;}
.cc-demo.band .dm-eyebrow::before{content:"";width:18px;height:1px;background:var(--o);}
.cc-demo.band h3{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.6vw,28px);line-height:1.18;letter-spacing:-.01em;margin:0 0 11px;color:var(--ink);}
.cc-demo.band h3 em{font-style:italic;color:var(--o);}
.cc-demo.band p{font-size:15px;line-height:1.6;color:var(--ink2);margin:0 0 18px;max-width:46ch;}
.cc-demo.band .dm-go{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:600;font-size:14px;
  background:var(--o);color:#fff;border-radius:8px;padding:12px 20px;transition:background .15s,gap .15s;}
.cc-demo.band a.dm-root:hover .dm-go{background:var(--o-br);gap:12px;}
.cc-demo.band .dm-go svg{width:15px;height:15px;}
.cc-demo.band .dm-newtab{display:block;margin-top:11px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted2);}
@media(max-width:720px){ .cc-demo.band a.dm-root{grid-template-columns:1fr;gap:20px;} .cc-demo.band .dm-media{order:-1;} }

/* ---------- CARD layout (inline / end of article) ---------- */
.cc-demo.card a.dm-root{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px;
  display:flex;align-items:center;gap:18px;transition:border-color .16s,box-shadow .16s,transform .16s;}
.cc-demo.card a.dm-root:hover{border-color:var(--o);box-shadow:0 14px 30px -20px rgba(199,91,34,.5);transform:translateY(-2px);}
.cc-demo.card a.dm-root:hover .dm-launch{opacity:1;}
.cc-demo.card .dm-media{flex:none;width:190px;}
.cc-demo.card .dm-body{min-width:0;}
.cc-demo.card .dm-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--o);margin-bottom:7px;}
.cc-demo.card h3{font-family:var(--serif);font-weight:500;font-size:19px;line-height:1.22;margin:0 0 6px;color:var(--ink);}
.cc-demo.card p{font-size:13.5px;line-height:1.55;color:var(--ink2);margin:0 0 12px;}
.cc-demo.card .dm-go{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:13px;color:var(--o);transition:gap .15s,color .15s;}
.cc-demo.card a.dm-root:hover .dm-go{color:var(--o-br);gap:11px;}
.cc-demo.card .dm-go svg{width:14px;height:14px;}
@media(max-width:560px){ .cc-demo.card a.dm-root{flex-direction:column;align-items:stretch;} .cc-demo.card .dm-media{width:100%;} }

/* ---------- BUTTON layout (just a link/button, no preview) ---------- */
.cc-demo.button a.dm-root{display:inline-flex;align-items:center;gap:10px;background:var(--dark);color:#fff;
  border-radius:9px;padding:13px 20px;font-family:var(--sans);font-weight:600;font-size:14px;transition:background .15s,gap .15s;}
.cc-demo.button a.dm-root:hover{background:var(--o);gap:13px;}
.cc-demo.button .dm-dot{width:8px;height:8px;border-radius:50%;background:var(--o-br);flex:none;}
.cc-demo.button a.dm-root:hover .dm-dot{background:#fff;}
.cc-demo.button svg{width:15px;height:15px;}
