:root {
  --ink: #142c2b;
  --ink-soft: #526765;
  --forest: #123d3a;
  --forest-2: #1d514c;
  --mint: #dff3eb;
  --mint-2: #9ed9c6;
  --coral: #f36d52;
  --coral-soft: #ffe4de;
  --paper: #f7f8f3;
  --white: #fff;
  --line: #dde5df;
  --yellow: #f5c85b;
  --blue: #5c8bd9;
  --shadow: 0 18px 50px rgba(20, 44, 43, .09);
  --radius: 18px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: "DM Sans", "Noto Sans SC", sans-serif; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }

.app-shell { min-height: 100vh; display: flex; }
.sidebar { position: fixed; inset: 0 auto 0 0; width: 244px; padding: 30px 20px 20px; background: var(--forest); color: #eef8f4; display: flex; flex-direction: column; z-index: 30; }
.brand { color: inherit; text-decoration: none; display: flex; align-items: center; gap: 12px; padding: 0 9px; }
.brand-mark { width: 40px; height: 40px; border-radius: 12px 12px 4px 12px; background: var(--coral); display: grid; place-items: center; font-weight: 800; font-size: 22px; }
.brand strong, .brand small { display: block; }
.brand strong { font-size: 18px; letter-spacing: .04em; }
.brand small { margin-top: 2px; color: #9fbab5; font-size: 9px; letter-spacing: .18em; }
.nav-list { margin-top: 46px; display: grid; gap: 8px; }
.nav-item { border: 0; background: transparent; color: #a9c1bd; text-align: left; padding: 13px 14px; border-radius: 12px; cursor: pointer; font-weight: 600; display: flex; align-items: center; gap: 12px; transition: .2s ease; }
.nav-item:hover, .nav-item.active { background: rgba(255,255,255,.1); color: white; }
.nav-item.active { box-shadow: inset 3px 0 var(--coral); }
.nav-icon { width: 20px; text-align: center; font-size: 18px; }
.sidebar-card { margin-top: auto; padding: 17px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); border-radius: 15px; }
.sidebar-card strong { display: block; margin-top: 7px; }
.sidebar-card p { margin: 6px 0 14px; color: #a9c1bd; font-size: 12px; line-height: 1.7; }
.profile-progress { height: 4px; border-radius: 9px; background: rgba(255,255,255,.12); overflow: hidden; }
.profile-progress span { display: block; width: 72%; height: 100%; background: var(--coral); }
.sidebar-card small { display: block; color: #9fbab5; font-size: 10px; margin-top: 8px; }
.sidebar-footer { display: flex; gap: 8px; align-items: center; margin: 18px 5px 0; color: #87a6a0; font-size: 10px; }
.status-dot { width: 7px; height: 7px; border-radius: 50%; background: #65d49e; box-shadow: 0 0 0 4px rgba(101,212,158,.1); }

.main-content { margin-left: 244px; width: calc(100% - 244px); min-width: 0; }
.topbar { height: 72px; padding: 0 35px; background: rgba(247,248,243,.92); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 20; }
.breadcrumb { color: #788a87; font-size: 13px; }
.breadcrumb b { color: var(--ink); }
.top-actions { display: flex; align-items: center; gap: 10px; }
.avatar { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; background: var(--mint); color: var(--forest); font-size: 12px; font-weight: 800; }
.icon-button { width: 35px; height: 35px; border-radius: 50%; border: 1px solid var(--line); background: white; cursor: pointer; font-family: Georgia, serif; font-weight: 700; }
.mobile-menu { display: none; border: 0; background: transparent; font-size: 22px; }
.content-wrap { padding: 34px 36px 60px; max-width: 1560px; margin: 0 auto; }
.view { display: none; animation: fadeUp .32s ease; }
.view.active { display: block; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.hero-panel { min-height: 325px; background: var(--forest); color: white; border-radius: 24px; padding: 48px 52px; display: grid; grid-template-columns: 1.45fr .75fr; gap: 50px; position: relative; overflow: hidden; }
.hero-panel:before, .hero-panel:after { content: ""; position: absolute; border: 1px solid rgba(255,255,255,.08); border-radius: 50%; }
.hero-panel:before { width: 430px; height: 430px; right: -190px; top: -120px; }
.hero-panel:after { width: 260px; height: 260px; right: -70px; top: -35px; }
.hero-copy { position: relative; z-index: 1; }
.eyebrow { color: #7d918e; font-size: 10px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.eyebrow.light { color: #9ac0b8; }
.hero-copy h1 { margin: 14px 0 16px; max-width: 710px; font-size: clamp(32px, 3vw, 48px); line-height: 1.18; letter-spacing: -.035em; }
.hero-copy p { max-width: 620px; color: #b6ccc7; line-height: 1.8; font-size: 14px; }
.hero-actions { display: flex; gap: 12px; margin-top: 27px; }
.primary-button, .white-button, .ghost-button, .outline-button { border-radius: 10px; padding: 11px 17px; border: 0; font-weight: 700; font-size: 13px; cursor: pointer; transition: .2s ease; }
.primary-button { background: var(--coral); color: white; box-shadow: 0 8px 20px rgba(243,109,82,.2); }
.primary-button:hover { transform: translateY(-1px); background: #df5d45; }
.primary-button.compact { padding: 9px 14px; }
.primary-button.full { width: 100%; padding: 13px 17px; }
.white-button { background: white; color: var(--forest); padding: 13px 19px; }
.white-button span { margin-left: 14px; }
.ghost-button { color: white; background: transparent; border: 1px solid rgba(255,255,255,.25); }
.outline-button { background: white; color: var(--forest); border: 1px solid var(--line); }
.outline-button:hover { border-color: var(--forest); }
.outline-button.small { padding: 7px 11px; font-size: 11px; }
.text-button { border: 0; background: transparent; color: var(--coral); font-size: 12px; font-weight: 700; cursor: pointer; }
.hero-score-card { position: relative; z-index: 1; border-radius: 18px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.12); padding: 21px; backdrop-filter: blur(10px); }
.score-heading { display: flex; justify-content: space-between; color: #a7c2bd; font-size: 10px; font-weight: 700; letter-spacing: .08em; }
.live-tag { color: #7fe3ae; }
.score-country { display: grid; grid-template-columns: auto 1fr auto; gap: 11px; align-items: center; padding: 17px 0 15px; border-bottom: 1px solid rgba(255,255,255,.12); }
.score-country .flag { font-size: 28px; }
.score-country strong, .score-country small { display: block; }
.score-country strong { font-size: 18px; }.score-country small { color: #97b2ad; font-size: 10px; margin-top: 2px; }.score-country b { font-size: 31px; color: var(--yellow); }
.score-line { display: grid; grid-template-columns: 73px 1fr 35px; align-items: center; gap: 8px; margin-top: 14px; font-size: 10px; color: #a7c2bd; }
.score-line div { height: 4px; border-radius: 5px; background: rgba(255,255,255,.12); overflow: hidden; }.score-line i { display: block; height: 100%; background: var(--mint-2); border-radius: 5px; }.score-line b { text-align: right; color: white; }
.hero-score-card > p { margin: 16px 0 0; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.12); color: #aac3be; font-size: 10px; line-height: 1.65; }

.section-heading { display: flex; align-items: end; justify-content: space-between; margin: 34px 0 14px; }
.section-heading h2, .page-heading h1 { margin: 7px 0 0; font-size: 25px; letter-spacing: -.025em; }
.hs-switch { display: inline-flex; padding: 4px; gap: 3px; background: #e8ede8; border-radius: 10px; }
.hs-switch button { border: 0; background: transparent; color: #71827f; padding: 7px 12px; border-radius: 7px; font-size: 11px; font-weight: 700; cursor: pointer; }
.hs-switch button.active { background: white; color: var(--forest); box-shadow: 0 3px 12px rgba(20,44,43,.08); }
.hs-switch.large button { padding: 9px 15px; }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.product-card { border: 1px solid var(--line); background: white; border-radius: 14px; padding: 14px; display: grid; grid-template-columns: auto 1fr auto; gap: 11px; align-items: center; text-align: left; cursor: pointer; transition: .2s ease; }
.product-card:hover, .product-card.selected { border-color: var(--forest); box-shadow: 0 10px 28px rgba(20,44,43,.07); transform: translateY(-2px); }
.product-icon { width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; font-size: 20px; }.product-icon.coral { background: var(--coral-soft); color: var(--coral); }.product-icon.mint { background: var(--mint); color: var(--forest-2); }.product-icon.blue { background: #e4ecfb; color: var(--blue); }.product-icon.yellow { background: #fff1c7; color: #9a6c00; }
.product-card strong, .product-card small { display: block; }.product-card strong { font-size: 13px; }.product-card small { color: #83928f; font-size: 9px; margin-top: 3px; }.product-card i { width: 21px; height: 21px; border: 1px solid var(--line); border-radius: 50%; display: grid; place-items: center; font-size: 10px; font-style: normal; color: #8b9b98; }.product-card.selected i { border-color: var(--forest); background: var(--forest); color: white; }
.classification-note { margin-top: 12px; display: flex; gap: 10px; align-items: center; padding: 11px 14px; background: #fff7e2; border: 1px solid #f1dfad; border-radius: 11px; color: #705c27; font-size: 11px; }.classification-note > span { flex: 0 0 23px; width: 23px; height: 23px; border-radius: 50%; background: var(--yellow); display: grid; place-items: center; font-weight: 800; }.classification-note p { margin: 0; line-height: 1.6; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 22px; }
.stat-card { background: white; border: 1px solid var(--line); border-radius: 14px; padding: 18px; }.stat-card span { color: #7c8e8a; font-size: 10px; }.stat-card strong { display: block; font-size: 24px; margin: 9px 0 4px; letter-spacing: -.03em; }.stat-card small { font-size: 10px; color: #859591; }.stat-card small.up { color: #159162; }
.dashboard-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 15px; margin-top: 15px; }
.panel { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; box-shadow: 0 8px 30px rgba(20,44,43,.03); }
.panel-header { display: flex; justify-content: space-between; align-items: start; margin-bottom: 18px; }.panel-header h3, .next-step-panel h3, .followup-panel h3 { margin: 5px 0 0; font-size: 17px; }
.source-pill { color: #718580; background: #edf1ed; border-radius: 20px; padding: 6px 9px; font-size: 9px; font-weight: 700; }.source-pill.dark { background: var(--forest); color: white; align-self: center; }
.market-preview-row { display: grid; grid-template-columns: 27px 1.1fr .9fr .8fr 42px; align-items: center; gap: 10px; padding: 12px 0; border-top: 1px solid #edf1ed; font-size: 11px; cursor: pointer; }.market-preview-row:first-child { border-top: 0; }.market-preview-row:hover strong { color: var(--coral); }.rank-badge { width: 23px; height: 23px; border-radius: 7px; background: var(--mint); display: grid; place-items: center; font-weight: 800; font-size: 9px; }.market-name strong, .market-name small { display: block; }.market-name small { color: #899894; font-size: 9px; margin-top: 2px; }.market-metric span { display: block; color: #8b9a97; font-size: 8px; }.market-metric b { font-size: 11px; }.score-badge { padding: 6px; text-align: center; border-radius: 8px; background: var(--forest); color: white; font-weight: 800; }
.bar-chart { min-height: 260px; display: flex; align-items: end; justify-content: space-around; gap: 10px; padding-top: 15px; }.bar-column { height: 225px; display: flex; flex: 1; flex-direction: column; align-items: center; justify-content: end; gap: 7px; }.bar-column b { font-size: 9px; color: #5c6f6b; }.bar { width: min(42px, 72%); min-height: 8px; background: var(--mint-2); border-radius: 7px 7px 2px 2px; transition: .4s ease; position: relative; }.bar-column:first-child .bar { background: var(--coral); }.bar-column span { color: #738682; font-size: 9px; white-space: nowrap; }
.next-step-panel { margin-top: 15px; display: grid; grid-template-columns: 1.1fr 2fr auto; align-items: center; gap: 30px; }.next-step-panel p { color: #748581; font-size: 11px; margin: 7px 0 0; }.step-flow { display: flex; align-items: center; gap: 9px; }.step-flow span { color: #667b77; font-size: 10px; text-align: center; }.step-flow b { display: block; color: var(--coral); margin-bottom: 5px; }.step-flow i { color: #b9c4c1; font-style: normal; }

.page-heading { display: flex; justify-content: space-between; align-items: end; margin-bottom: 25px; }.page-heading h1 { font-size: 31px; }.page-heading p { color: #768783; margin: 9px 0 0; font-size: 12px; }
.filter-panel { display: flex; align-items: center; gap: 10px; padding: 12px; border: 1px solid var(--line); background: white; border-radius: 14px; margin-bottom: 14px; }
.search-box { height: 38px; min-width: 210px; margin-left: auto; display: flex; align-items: center; gap: 7px; border: 1px solid var(--line); border-radius: 9px; padding: 0 10px; background: #fafbf8; }.search-box.wide { min-width: 330px; margin-left: 0; flex: 1; }.search-box input { width: 100%; border: 0; outline: 0; background: transparent; font-size: 11px; color: var(--ink); }.filter-panel select, .campaign-form select, .campaign-form input { height: 38px; border: 1px solid var(--line); background: #fafbf8; border-radius: 9px; padding: 0 11px; color: var(--ink); font-size: 11px; outline: 0; }
.market-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 11px; margin-bottom: 14px; }.summary-card { border-radius: 14px; padding: 16px 18px; color: white; background: var(--forest); }.summary-card:nth-child(2) { background: #eaf3ed; color: var(--forest); }.summary-card:nth-child(3) { background: #fff0e9; color: #813f31; }.summary-card span { font-size: 9px; opacity: .7; }.summary-card strong { display: block; font-size: 19px; margin-top: 7px; }
.table-card { overflow: hidden; background: white; border: 1px solid var(--line); border-radius: 15px; }.table-card table { width: 100%; border-collapse: collapse; }.table-card th { background: #f2f5f1; color: #788985; padding: 12px 14px; font-size: 9px; text-align: left; letter-spacing: .04em; }.table-card td { border-top: 1px solid #e9efea; padding: 13px 14px; font-size: 11px; vertical-align: middle; }.table-card tbody tr { transition: .15s ease; }.table-card tbody tr:hover { background: #fbfcf9; }.country-cell { display: flex; align-items: center; gap: 9px; }.country-cell .flag { font-size: 21px; }.country-cell strong, .country-cell small { display: block; }.country-cell small { color: #8c9a97; font-size: 8px; margin-top: 2px; }.growth-up { color: #128159; font-weight: 700; }.growth-down { color: #bd5d4b; font-weight: 700; }.mini-progress { width: 95px; height: 5px; border-radius: 5px; background: #e9eeea; overflow: hidden; margin-top: 5px; }.mini-progress i { display: block; height: 100%; background: var(--mint-2); }.table-score { display: flex; align-items: center; gap: 7px; }.table-score b { font-size: 14px; }.level-pill, .signal-pill, .type-pill { display: inline-block; padding: 5px 8px; border-radius: 20px; font-size: 8px; font-weight: 800; }.level-pill.priority, .signal-pill.hot { background: var(--coral-soft); color: #b74935; }.level-pill.test, .signal-pill.warm { background: #fff0c8; color: #8a650e; }.level-pill.watch { background: #edf0ed; color: #657572; }.row-action { border: 0; background: transparent; color: var(--coral); font-size: 10px; font-weight: 700; cursor: pointer; white-space: nowrap; }.method-note { color: #7d8d89; font-size: 9px; line-height: 1.7; padding: 12px 4px; }

.region-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 14px; }
.region-tabs { display: inline-flex; padding: 4px; background: white; border: 1px solid var(--line); border-radius: 11px; }
.region-tabs button { min-width: 72px; border: 0; border-radius: 7px; padding: 8px 12px; background: transparent; color: #71827f; font-size: 10px; font-weight: 700; cursor: pointer; }
.region-tabs button.active { color: white; background: var(--forest); }
.region-hero-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 13px; }
.region-hero-card { min-height: 190px; position: relative; overflow: hidden; padding: 21px; border: 1px solid var(--line); border-radius: 17px; background: white; text-align: left; cursor: pointer; transition: .22s ease; }
.region-hero-card:after { content:""; position:absolute; width:140px; height:140px; right:-60px; top:-50px; border-radius:50%; background: currentColor; opacity:.08; }
.region-hero-card:hover, .region-hero-card.selected { transform: translateY(-3px); box-shadow: var(--shadow); border-color: currentColor; }
.region-hero-card.coral { color: var(--coral); }.region-hero-card.mint { color: #21866a; }.region-hero-card.yellow { color: #a57812; }
.region-code { display: inline-grid; place-items:center; width:37px; height:37px; border-radius:10px; background: currentColor; color:white; font-size:10px; font-weight:800; letter-spacing:.06em; }
.region-card-label { margin-left: 9px; color: #83938f; font-size: 9px; letter-spacing:.08em; }
.region-hero-card > strong, .region-hero-card > small { display:block; color:var(--ink); }.region-hero-card > strong { margin-top:17px; font-size:21px; }.region-hero-card > small { margin-top:2px; color:#8a9996; font-size:9px; }
.region-card-main { display:flex; align-items:end; justify-content:space-between; margin-top:16px; color:var(--ink); }.region-card-main b { font-size:25px; letter-spacing:-.04em; }.region-card-main span { font-size:11px; }
.region-card-footer { display:flex; justify-content:space-between; margin-top:13px; padding-top:11px; border-top:1px solid var(--line); color:#71837f; font-size:9px; }
.region-analysis-grid { display:grid; grid-template-columns:1.25fr .75fr; gap:14px; margin-top:14px; }
.region-matrix { display:grid; gap:18px; }.matrix-row { display:grid; grid-template-columns:95px 1fr 32px; align-items:center; gap:15px; }.matrix-name strong, .matrix-name small { display:block; }.matrix-name strong { font-size:12px; }.matrix-name small { color:#879692; font-size:8px; margin-top:2px; }.matrix-row > b { font-size:17px; }
.matrix-bars { display:grid; gap:5px; }.matrix-bars span { display:block; height:6px; border-radius:9px; background:#edf1ed; overflow:hidden; }.matrix-bars i { display:block; height:100%; border-radius:9px; }.matrix-bars i.scale, .matrix-legend i.scale { background:var(--forest); }.matrix-bars i.growth, .matrix-legend i.growth { background:var(--coral); }.matrix-bars i.share, .matrix-legend i.share { background:var(--mint-2); }
.matrix-legend { display:flex; gap:16px; margin-top:17px; padding-top:13px; border-top:1px solid var(--line); color:#7c8d89; font-size:8px; }.matrix-legend span { display:flex; align-items:center; gap:5px; }.matrix-legend i { width:7px; height:7px; border-radius:2px; }
.strategy-region-title { display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:11px; margin-top:14px; }.strategy-region-title h3, .strategy-region-title small { display:block; margin:0; }.strategy-region-title h3 { font-size:21px; }.strategy-region-title small { color:#83938f; font-size:9px; margin-top:2px; }.strategy-region-title > b { font-size:31px; color:var(--coral); }.region-code.coral { background:var(--coral); }.region-code.mint { background:#21866a; }.region-code.yellow { background:#c28d1b; }
.region-strategy-panel > p { color:#667975; font-size:10px; line-height:1.75; margin:17px 0; padding:13px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }.strategy-fact { margin-top:12px; }.strategy-fact span, .strategy-fact strong { display:block; }.strategy-fact span { color:#84938f; font-size:8px; }.strategy-fact strong { margin-top:4px; font-size:10px; line-height:1.55; }
.region-country-heading { margin-top:27px; }.region-country-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.region-country-card { position:relative; padding:17px; border:1px solid var(--line); border-radius:15px; background:white; transition:.2s ease; }.region-country-card:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(20,44,43,.07); }.region-country-top { display:flex; align-items:center; justify-content:space-between; }.region-country-top .flag { font-size:28px; }.region-rank { color:#84938f; font-size:9px; font-weight:800; }.region-country-card h3 { margin:10px 0 13px; font-size:15px; }.region-country-card h3 small { display:block; color:#8a9996; font-size:8px; font-weight:500; margin-top:3px; }.country-opportunity { position:absolute; right:17px; top:54px; text-align:right; }.country-opportunity b, .country-opportunity span { display:block; }.country-opportunity b { color:var(--coral); font-size:20px; }.country-opportunity span { color:#8c9996; font-size:7px; }.country-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:5px; padding-top:13px; border-top:1px solid var(--line); }.country-metrics span { min-width:0; }.country-metrics small, .country-metrics b { display:block; }.country-metrics small { color:#8b9996; font-size:7px; }.country-metrics b { margin-top:5px; font-size:10px; }.country-share-line { height:4px; margin:13px 0 10px; border-radius:8px; background:#eaf0eb; overflow:hidden; }.country-share-line i { display:block; height:100%; border-radius:8px; background:var(--mint-2); }
.region-verdict-panel { display:grid; grid-template-columns:190px 1fr auto; align-items:center; gap:22px; margin-top:14px; }.region-verdict-panel h3 { margin:5px 0 0; font-size:17px; }.region-action-list { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }.region-action-list span { color:#5e716d; font-size:9px; line-height:1.55; }.region-action-list b { display:block; color:var(--coral); margin-bottom:5px; }

.demo-banner { display: flex; gap: 11px; align-items: center; background: #fff5dc; border: 1px solid #ecdcae; border-radius: 12px; padding: 11px 14px; color: #765e21; margin-bottom: 14px; }.demo-banner span { background: var(--yellow); border-radius: 5px; padding: 4px 7px; font-weight: 800; font-size: 8px; }.demo-banner p { margin: 0; font-size: 10px; line-height: 1.6; }
.lead-kpis { display: grid; grid-template-columns: repeat(4,1fr); border: 1px solid var(--line); border-radius: 14px; background: white; margin-bottom: 14px; }.lead-kpis div { padding: 15px 18px; border-left: 1px solid var(--line); }.lead-kpis div:first-child { border-left: 0; }.lead-kpis span { color: #7d8d89; font-size: 9px; }.lead-kpis strong { display: block; margin-top: 6px; font-size: 20px; }.company-cell strong, .company-cell small { display: block; }.company-cell small { margin-top: 3px; color: #879692; font-size: 8px; }.type-pill { background: var(--mint); color: var(--forest-2); }.match-products { max-width: 165px; color: #61736f; }.role-list { color: #495f5b; font-size: 9px; line-height: 1.5; }.favorite-button { border: 0; background: transparent; font-size: 19px; cursor: pointer; color: #bac5c2; }.favorite-button.active { color: var(--yellow); }

.campaign-layout { display: grid; grid-template-columns: .82fr 1.18fr; gap: 15px; }.campaign-form label { display: grid; gap: 6px; color: #657874; font-size: 10px; font-weight: 700; margin-top: 15px; }.campaign-form label:first-of-type { margin-top: 0; }.campaign-form textarea, .email-preview textarea { border: 1px solid var(--line); background: #fafbf8; border-radius: 10px; padding: 12px; resize: vertical; outline: none; color: var(--ink); font-size: 11px; line-height: 1.7; }.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }.tone-options { display: flex; gap: 6px; align-items: center; margin: 16px 0; }.tone-options > span { margin-right: auto; color: #687b77; font-size: 10px; font-weight: 700; }.tone-options button { border: 1px solid var(--line); background: white; padding: 6px 8px; border-radius: 7px; font-size: 9px; cursor: pointer; }.tone-options button.active { color: white; border-color: var(--forest); background: var(--forest); }.email-preview { display: flex; flex-direction: column; }.email-meta { display: grid; grid-template-columns: 52px 1fr; align-items: center; border: 1px solid var(--line); border-radius: 10px 10px 0 0; overflow: hidden; }.email-meta label { padding-left: 12px; color: #879692; font-size: 9px; font-weight: 700; }.email-meta input { height: 42px; border: 0; border-left: 1px solid var(--line); padding: 0 12px; outline: none; font-size: 11px; }.email-preview textarea { min-height: 345px; border-radius: 0 0 10px 10px; border-top: 0; background: white; }.email-quality { display: flex; flex-wrap: wrap; gap: 15px; padding-top: 13px; color: #738581; font-size: 8px; }.email-quality span { display: flex; align-items: center; gap: 5px; }.email-quality i { width: 6px; height: 6px; border-radius: 50%; }.email-quality i.good { background: #36ae7c; }.email-quality i.warn { background: var(--yellow); }.followup-panel { display: grid; grid-template-columns: 180px 1fr; align-items: center; margin-top: 15px; }.timeline { display: flex; align-items: center; }.timeline span { flex: 1; text-align: center; color: #758783; font-size: 9px; }.timeline span b { display: block; color: var(--ink); margin-bottom: 4px; }.timeline span.active b { color: var(--coral); }.timeline i { width: 30px; height: 1px; background: var(--line); }

.drawer-backdrop, .modal-backdrop { position: fixed; inset: 0; background: rgba(10,30,28,.35); backdrop-filter: blur(2px); opacity: 0; pointer-events: none; transition: .25s ease; z-index: 50; }.drawer-backdrop.open, .modal-backdrop.open { opacity: 1; pointer-events: auto; }.detail-drawer { position: fixed; right: 0; top: 0; bottom: 0; width: min(480px, 92vw); background: white; transform: translateX(102%); transition: .3s ease; z-index: 60; padding: 34px; overflow-y: auto; box-shadow: -20px 0 60px rgba(15,40,37,.16); }.detail-drawer.open { transform: none; }.drawer-close { position: absolute; right: 18px; top: 15px; width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--line); background: white; cursor: pointer; font-size: 18px; }.drawer-hero { padding: 8px 0 22px; border-bottom: 1px solid var(--line); }.drawer-hero .flag { font-size: 38px; }.drawer-hero h2 { margin: 10px 0 5px; font-size: 26px; }.drawer-hero p { color: #788a86; margin: 0; font-size: 11px; line-height: 1.6; }.drawer-score { display: inline-flex; align-items: baseline; gap: 4px; margin-top: 15px; padding: 8px 11px; background: var(--forest); color: white; border-radius: 9px; }.drawer-score b { font-size: 22px; }.drawer-score span { font-size: 9px; opacity: .7; }.detail-section { padding: 20px 0; border-bottom: 1px solid var(--line); }.detail-section h3 { margin: 0 0 12px; font-size: 14px; }.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }.detail-box { padding: 12px; border-radius: 10px; background: #f4f6f2; }.detail-box span, .detail-box strong { display: block; }.detail-box span { color: #82918e; font-size: 8px; }.detail-box strong { margin-top: 5px; font-size: 12px; }.bullet-list { margin: 0; padding-left: 16px; color: #5d716d; font-size: 10px; line-height: 1.85; }.role-card { padding: 12px; margin-top: 8px; display: flex; justify-content: space-between; gap: 10px; border: 1px solid var(--line); border-radius: 11px; }.role-card strong, .role-card small { display: block; }.role-card small { color: #879793; font-size: 8px; margin-top: 3px; }.role-status { align-self: center; color: #c05b45; background: var(--coral-soft); padding: 5px 7px; border-radius: 15px; white-space: nowrap; font-size: 8px; font-weight: 700; }.drawer-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding-top: 20px; }
.modal-backdrop { display: grid; place-items: center; z-index: 80; }.modal { width: min(480px, 90vw); background: white; border-radius: 18px; padding: 30px; position: relative; transform: translateY(12px); transition: .25s ease; }.modal-backdrop.open .modal { transform: none; }.modal h2 { margin: 8px 0 12px; }.modal p, .modal li { color: #667975; font-size: 11px; line-height: 1.8; }.modal ul { padding-left: 18px; margin-bottom: 22px; }
.toast { position: fixed; left: 50%; bottom: 25px; transform: translate(-50%, 20px); padding: 10px 15px; border-radius: 9px; background: var(--forest); color: white; font-size: 10px; opacity: 0; pointer-events: none; transition: .25s ease; z-index: 100; }.toast.show { opacity: 1; transform: translate(-50%,0); }

@media (max-width: 1100px) {
  .product-grid { grid-template-columns: repeat(2, 1fr); }.dashboard-grid, .region-analysis-grid { grid-template-columns: 1fr; }.next-step-panel, .region-verdict-panel { grid-template-columns: 1fr; }.campaign-layout { grid-template-columns: 1fr; }.table-card { overflow-x: auto; }.table-card table { min-width: 850px; }.step-flow { justify-content: space-between; }.region-country-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 820px) {
  .sidebar { transform: translateX(-100%); transition: .25s ease; }.sidebar.open { transform: none; }.main-content { margin-left: 0; width: 100%; }.mobile-menu { display: inline-block; }.topbar { padding: 0 16px; }.topbar .compact { display: none; }.content-wrap { padding: 20px 15px 50px; }.hero-panel { grid-template-columns: 1fr; padding: 30px 24px; }.hero-score-card { display: none; }.hero-copy h1 { font-size: 31px; }.stats-grid { grid-template-columns: repeat(2, 1fr); }.page-heading { align-items: start; gap: 16px; }.filter-panel { align-items: stretch; flex-wrap: wrap; }.search-box { margin-left: 0; flex: 1; }.market-summary { grid-template-columns: 1fr; }.lead-kpis { grid-template-columns: repeat(2, 1fr); }.lead-kpis div:nth-child(3) { border-left: 0; border-top: 1px solid var(--line); }.lead-kpis div:nth-child(4) { border-top: 1px solid var(--line); }.followup-panel { grid-template-columns: 1fr; gap: 20px; }.region-hero-grid { grid-template-columns:1fr; }.region-toolbar { align-items:stretch; flex-direction:column; }.region-tabs button { flex:1; }
}
@media (max-width: 540px) {
  .product-grid, .stats-grid, .region-country-grid { grid-template-columns: 1fr; }.section-heading { align-items: start; gap: 14px; flex-direction: column; }.hero-actions { align-items: stretch; flex-direction: column; }.page-heading { flex-direction: column; }.page-heading .primary-button, .page-heading .outline-button { width: 100%; }.hs-switch.large { width: 100%; }.hs-switch.large button { flex: 1; }.form-row { grid-template-columns: 1fr; }.timeline i { width: 8px; }.timeline span { font-size: 7px; }.detail-drawer { padding: 28px 20px; }.next-step-panel { gap: 18px; }.step-flow span { font-size: 8px; }.step-flow i { display: none; }.matrix-row { grid-template-columns:70px 1fr 25px; gap:8px; }.region-action-list { grid-template-columns:1fr; }.region-verdict-panel { gap:16px; }
}
