/*
 * Romania IPTV — Global Design System
 * Single source of truth for tokens, typography, components & utilities.
 * Load order: Bootstrap → global.css → page/component inline styles (for overrides only)
 * -------------------------------------------------------------------------
 */

/* =========================================================================
   1. DESIGN TOKENS
   ========================================================================= */
:root {
  /* Brand palette */
  --clr-blue:         #002B7F;
  --clr-blue-mid:     #003399;
  --clr-blue-dark:    #001d5c;
  --clr-blue-a10:     rgba(0, 43, 127, .10);
  --clr-blue-a15:     rgba(0, 43, 127, .15);
  --clr-blue-a25:     rgba(0, 43, 127, .25);
  --clr-red:          #CE1126;
  --clr-red-dark:     #a80e1e;
  --clr-red-a35:      rgba(206, 17, 38, .35);
  --clr-yellow:       #FCD116;

  /* Neutral palette */
  --clr-white:        #ffffff;
  --clr-surface:      #f8f9fb;
  --clr-surface-alt:  #f0f2f5;
  --clr-border:       #eef0f2;
  --clr-border-mid:   #e2e8f0;

  /* Text */
  --clr-text:         #111827;
  --clr-text-body:    #374151;
  --clr-text-muted:   #6b7280;
  --clr-text-light:   #9ca3af;

  /* ---- Typography ---- */
  --font:             'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --fs-xs:    0.75rem;
  --fs-sm:    0.875rem;
  --fs-base:  1rem;
  --fs-lg:    1.125rem;
  --fs-xl:    1.25rem;
  --fs-2xl:   1.5rem;
  --fs-3xl:   clamp(1.5rem, 3vw, 2rem);
  --fs-4xl:   clamp(1.75rem, 3.5vw, 2.5rem);
  --fs-5xl:   clamp(2rem, 4vw, 3rem);

  --fw-normal:  400;
  --fw-medium:  500;
  --fw-semi:    600;
  --fw-bold:    700;
  --fw-black:   800;

  --lh-tight:   1.2;
  --lh-snug:    1.35;
  --lh-normal:  1.6;
  --lh-relaxed: 1.75;

  /* ---- Spacing scale ---- */
  --sp-1:   0.25rem;
  --sp-2:   0.5rem;
  --sp-3:   0.75rem;
  --sp-4:   1rem;
  --sp-5:   1.25rem;
  --sp-6:   1.5rem;
  --sp-8:   2rem;
  --sp-10:  2.5rem;
  --sp-12:  3rem;
  --sp-16:  4rem;
  --sp-20:  5rem;
  --sp-24:  6rem;

  /* ---- Border radius ---- */
  --r-sm:   8px;
  --r-md:   12px;
  --r-lg:   16px;
  --r-xl:   24px;
  --r-2xl:  32px;
  --r-pill: 999px;

  /* ---- Shadows ---- */
  --sh-xs:   0 1px 4px rgba(0,0,0,.05);
  --sh-sm:   0 2px 8px rgba(0,0,0,.07);
  --sh-md:   0 8px 24px rgba(0,0,0,.08);
  --sh-lg:   0 20px 50px rgba(0,0,0,.09);
  --sh-xl:   0 24px 60px rgba(0,0,0,.12);
  --sh-blue: 0 8px 24px var(--clr-blue-a25);
  --sh-red:  0 6px 20px var(--clr-red-a35);

  /* ---- Motion ---- */
  --ease:       cubic-bezier(.4, 0, .2, 1);
  --dur-fast:   150ms;
  --dur-base:   250ms;
  --dur-slow:   400ms;
  --transition: var(--dur-base) var(--ease);

  /* ---- Layout ---- */
  --section-py:    80px;
  --section-py-sm: 52px;
  --container-max: 1200px;
}

/* =========================================================================
   2. BASE RESET
   ========================================================================= */
*, *::before, *::after {
  box-sizing: border-box;
}

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

body {
  font-family: var(--font) !important;
  font-size: var(--fs-base);
  font-weight: var(--fw-normal);
  line-height: var(--lh-normal);
  color: var(--clr-text-body);
  background: var(--clr-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Fix Bootstrap bg-light on body — use white base */
body.bg-light {
  background-color: var(--clr-white) !important;
}

img, video {
  max-width: 100%;
  height: auto;
}

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

/* =========================================================================
   3. TYPOGRAPHY
   ========================================================================= */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  color: var(--clr-blue);
  letter-spacing: -0.01em;
}

p {
  font-family: var(--font);
  line-height: var(--lh-normal);
  color: var(--clr-text-body);
}

/* =========================================================================
   4. SECTION LAYOUT
   ========================================================================= */
.section-py       { padding: var(--section-py) 0; }
.section-py-sm    { padding: var(--section-py-sm) 0; }

/* Alternating section backgrounds */
.section-white    { background: var(--clr-white); }
.section-surface  { background: var(--clr-surface); }
.section-gradient {
  background: linear-gradient(180deg, var(--clr-surface) 0%, var(--clr-surface-alt) 100%);
}
.section-blue {
  background: var(--clr-blue);
  color: var(--clr-white);
}

/* =========================================================================
   5. SECTION HEADER (title + subtitle + decorative rule)
   ========================================================================= */
.section-header {
  margin-bottom: 3rem;
}

/* Optional badge above title */
.section-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clr-red);
  background: rgba(206, 17, 38, .08);
  border: 1px solid rgba(206, 17, 38, .18);
  padding: 0.3rem 0.75rem;
  border-radius: var(--r-pill);
  margin-bottom: 0.75rem;
}

/* Section title — consistent across all pages */
.section-title {
  font-family: var(--font) !important;
  font-size: var(--fs-3xl) !important;
  font-weight: var(--fw-black) !important;
  color: var(--clr-blue) !important;
  line-height: var(--lh-snug) !important;
  letter-spacing: -0.02em;
  margin-bottom: 0.75rem !important;
}

/* Decorative rule under the title */
.section-title::after {
  content: "";
  display: block;
  width: 48px;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-red) 0%, var(--clr-yellow) 100%);
  border-radius: var(--r-pill);
  margin: 0.75rem auto 0;
}

/* Left-aligned variant */
.section-title--left::after {
  margin-left: 0;
}

.section-subtitle {
  font-family: var(--font) !important;
  font-size: var(--fs-lg) !important;
  font-weight: var(--fw-normal) !important;
  color: var(--clr-text-muted) !important;
  line-height: var(--lh-normal);
  max-width: 640px;
  margin: 0 auto 0 !important;
}

.text-center .section-subtitle { margin-left: auto !important; margin-right: auto !important; }
.section-header .section-subtitle { margin-top: 0.5rem !important; }

/* =========================================================================
   6. BUTTON SYSTEM
   ========================================================================= */

/* Base shared by all RO buttons */
.btn-ro {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  font-family: var(--font);
  font-weight: var(--fw-semi);
  font-size: var(--fs-base);
  line-height: 1;
  white-space: nowrap;
  text-decoration: none !important;
  border: 2px solid transparent;
  border-radius: var(--r-md);
  padding: 0.8rem 1.6rem;
  cursor: pointer;
  transition: background var(--transition), color var(--transition),
              transform var(--transition), box-shadow var(--transition),
              border-color var(--transition);
}
.btn-ro:hover { transform: translateY(-2px); }
.btn-ro:active { transform: translateY(0); }
.btn-ro:focus-visible {
  outline: 3px solid var(--clr-blue-a25);
  outline-offset: 3px;
}

/* Primary — Blue fill */
.btn-ro-primary {
  background: var(--clr-blue);
  color: var(--clr-white) !important;
  border-color: var(--clr-blue);
  box-shadow: var(--sh-blue);
}
.btn-ro-primary:hover {
  background: var(--clr-blue-dark);
  border-color: var(--clr-blue-dark);
  color: var(--clr-white) !important;
  box-shadow: 0 10px 28px var(--clr-blue-a25);
}

/* Danger — Red fill (CTAs, buy, whatsapp) */
.btn-ro-danger {
  background: var(--clr-red);
  color: var(--clr-white) !important;
  border-color: var(--clr-red);
  box-shadow: var(--sh-red);
}
.btn-ro-danger:hover {
  background: var(--clr-red-dark);
  border-color: var(--clr-red-dark);
  color: var(--clr-white) !important;
  box-shadow: 0 10px 28px var(--clr-red-a35);
}

/* Outline — Blue border */
.btn-ro-outline {
  background: transparent;
  color: var(--clr-blue) !important;
  border-color: var(--clr-blue);
}
.btn-ro-outline:hover {
  background: var(--clr-blue-a10);
  color: var(--clr-blue) !important;
  box-shadow: var(--sh-blue);
}

/* Ghost — minimal, no border */
.btn-ro-ghost {
  background: transparent;
  color: var(--clr-blue) !important;
  border-color: transparent;
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}
.btn-ro-ghost:hover {
  color: var(--clr-red) !important;
  transform: none;
}

/* Sizes */
.btn-ro-sm { font-size: var(--fs-sm); padding: 0.55rem 1.1rem; border-radius: var(--r-sm); }
.btn-ro-lg { font-size: var(--fs-lg); padding: 1rem 2rem; border-radius: var(--r-lg); }
.btn-ro-xl { font-size: var(--fs-xl); padding: 1.1rem 2.4rem; border-radius: var(--r-lg); }

/* =========================================================================
   7. CARD SYSTEM
   ========================================================================= */
.card-ro {
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  padding: 1.75rem 1.5rem;
  transition: transform var(--transition), box-shadow var(--transition);
}

.card-ro:hover {
  transform: translateY(-5px);
  box-shadow: var(--sh-xl);
}

.card-ro--elevated {
  box-shadow: var(--sh-xl);
  border: none;
}

.card-ro--bordered {
  border: 2px solid var(--clr-blue-a10);
  box-shadow: var(--sh-sm);
}

/* =========================================================================
   8. ICON WRAPPER
   ========================================================================= */
.icon-wrap-ro {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: radial-gradient(circle at 30% 10%, rgba(255,255,255,.9), var(--clr-blue-a15));
  border: 1px solid rgba(255, 255, 255, .7);
  backdrop-filter: blur(8px);
  color: var(--clr-blue);
  font-size: 1.25rem;
  margin-bottom: 1rem;
  transition: transform var(--transition), box-shadow var(--transition);
}

.icon-wrap-ro--red {
  background: radial-gradient(circle at 30% 10%, rgba(255,255,255,.9), rgba(206,17,38,.14));
  color: var(--clr-red);
}

.icon-wrap-ro--yellow {
  background: radial-gradient(circle at 30% 10%, rgba(255,255,255,.9), rgba(252,209,22,.20));
  color: #c9960a;
}

.icon-wrap-ro--lg {
  width: 72px;
  height: 72px;
  font-size: 1.5rem;
}

.card-ro:hover .icon-wrap-ro,
.card-ro:hover .icon-wrap-ro--red,
.card-ro:hover .icon-wrap-ro--yellow {
  transform: scale(1.08);
  box-shadow: var(--sh-blue);
}

/* =========================================================================
   9. BADGE / PILL
   ========================================================================= */
.badge-ro {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.3rem 0.75rem;
  border-radius: var(--r-pill);
}

.badge-ro-blue {
  background: var(--clr-blue-a10);
  color: var(--clr-blue);
  border: 1px solid var(--clr-blue-a15);
}

.badge-ro-red {
  background: rgba(206, 17, 38, .08);
  color: var(--clr-red);
  border: 1px solid rgba(206, 17, 38, .18);
}

.badge-ro-green {
  background: rgba(34, 197, 94, .10);
  color: #15803d;
  border: 1px solid rgba(34, 197, 94, .25);
}

/* =========================================================================
   10. PAGE HERO (shared by about, faq, guide, legal, contact, etc.)
   ========================================================================= */
.page-hero {
  position: relative;
  padding: 72px 0 64px;
  background: radial-gradient(circle at top center, #ffffff 0%, var(--clr-surface) 70%);
  overflow: hidden;
  text-align: center;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 15% 40%, rgba(0,43,127,.04) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 85% 20%, rgba(206,17,38,.03) 0%, transparent 55%),
    radial-gradient(ellipse 50% 60% at 50% 100%, rgba(252,209,22,.03) 0%, transparent 55%);
  pointer-events: none;
}

.page-hero__inner {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
}

.page-hero__eyebrow {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-red);
  margin-bottom: 0.75rem;
  display: block;
}

.page-hero__title {
  font-size: clamp(1.85rem, 4vw, 2.75rem) !important;
  font-weight: var(--fw-black) !important;
  color: var(--clr-blue) !important;
  line-height: 1.2 !important;
  letter-spacing: -0.025em;
  margin-bottom: 0.75rem !important;
}

.page-hero__title .highlight,
.page-hero__title .text-danger {
  color: var(--clr-red) !important;
}

.page-hero__subtitle {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin-bottom: 0 !important;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.page-hero__breadcrumb {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.4rem;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  margin-bottom: 1.25rem;
}

.page-hero__breadcrumb a {
  color: var(--clr-blue);
  font-weight: var(--fw-medium);
  text-decoration: none;
}
.page-hero__breadcrumb a:hover { color: var(--clr-red); }
.page-hero__breadcrumb-sep { color: var(--clr-border-mid); }

/* =========================================================================
   11. DIVIDER
   ========================================================================= */
.divider-ro {
  width: 48px;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-red) 0%, var(--clr-yellow) 100%);
  border-radius: var(--r-pill);
  margin: 0.75rem auto;
  border: none;
}

.divider-ro--left { margin-left: 0; }

/* =========================================================================
   12. TRUST PILLS (reusable across hero, cta, etc.)
   ========================================================================= */
.trust-pills {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem 0.75rem;
}

.trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-blue);
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-pill);
  padding: 0.4rem 0.875rem;
  box-shadow: var(--sh-sm);
}

.trust-pill i {
  color: var(--clr-red);
  font-size: 0.85em;
}

/* =========================================================================
   13. STEP / PROCESS COMPONENT
   ========================================================================= */
.step-ro {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
}

.step-ro__num {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-sm);
  font-weight: var(--fw-black);
  background: var(--clr-blue);
  color: var(--clr-white);
  box-shadow: var(--sh-blue);
}

.step-ro__body h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-blue);
  margin-bottom: 0.25rem;
}

.step-ro__body p {
  font-size: var(--fs-base);
  color: var(--clr-text-muted);
  margin: 0;
}

/* =========================================================================
   14. LINK ARROW (inline navigation cue)
   ========================================================================= */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: var(--fw-semi);
  color: var(--clr-blue);
  text-decoration: none;
  font-size: var(--fs-sm);
}

.link-arrow::after {
  content: "→";
  transition: transform var(--dur-fast) var(--ease);
}

.link-arrow:hover { color: var(--clr-red); }
.link-arrow:hover::after { transform: translateX(3px); }

/* =========================================================================
   15. UTILITY OVERRIDES
   ========================================================================= */

/* Ensure all section titles use Inter, not Bootstrap defaults */
.section-title,
.about-section-title,
.about-hero__title,
.faq-hero__title,
.legal-hero__title,
.guide-hero__title,
.contact-page-hero__title,
.checkout-hero__title,
.pricing-hero__title,
.blog-hero__title {
  font-family: var(--font) !important;
}

/* Consistent heading color for all pages */
h1, h2, h3 { color: var(--clr-blue); }
h4, h5, h6 { color: var(--clr-text); }

/* ---- Links inside body text ---- */
.body-link {
  color: var(--clr-blue);
  font-weight: var(--fw-medium);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color var(--transition), border-color var(--transition);
}
.body-link:hover { color: var(--clr-red); border-bottom-color: var(--clr-red); }

/* ---- Focus rings ---- */
:focus-visible {
  outline: 2px solid var(--clr-blue-a25);
  outline-offset: 3px;
}

/* ---- Smooth container ---- */
.container { max-width: var(--container-max) !important; }

/* =========================================================================
   18. NAVBAR REFINEMENTS (supplements header.php inline)
   ========================================================================= */
.navbar-romania {
  font-family: var(--font);
  border-bottom: 1px solid var(--clr-border) !important;
  box-shadow: 0 1px 12px rgba(0, 0, 0, .05) !important;
}

.navbar-romania .nav-link {
  font-family: var(--font) !important;
  font-weight: var(--fw-medium) !important;
  font-size: var(--fs-base) !important;
  letter-spacing: -0.01em;
}

/* Active nav link indicator */
.navbar-romania .nav-link.active {
  color: var(--clr-blue) !important;
  font-weight: var(--fw-semi) !important;
}

/* =========================================================================
   19. FOOTER REFINEMENTS
   ========================================================================= */
.site-footer {
  font-family: var(--font) !important;
}

/* =========================================================================
   20. FORM INPUTS (global baseline)
   ========================================================================= */
.form-control,
.form-select {
  font-family: var(--font) !important;
  font-size: var(--fs-base) !important;
  border-radius: var(--r-md) !important;
  border-color: var(--clr-border-mid) !important;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--clr-blue) !important;
  box-shadow: 0 0 0 3px var(--clr-blue-a10) !important;
  outline: none;
}

.form-label {
  font-family: var(--font) !important;
  font-weight: var(--fw-medium) !important;
  font-size: var(--fs-sm) !important;
  color: var(--clr-text) !important;
  margin-bottom: 0.4rem;
}

/* =========================================================================
   21. RESPONSIVE ADJUSTMENTS
   ========================================================================= */
@media (max-width: 991.98px) {
  :root {
    --section-py: 64px;
    --section-py-sm: 44px;
  }

  .section-header { margin-bottom: 2.25rem; }
  .page-hero { padding: 56px 0 48px; }
}

@media (max-width: 767px) {
  :root {
    --section-py: 52px;
    --section-py-sm: 36px;
  }

  .section-header { margin-bottom: 1.75rem; }

  .btn-ro { padding: 0.75rem 1.4rem; }
  .btn-ro-lg { padding: 0.875rem 1.75rem; }

  .page-hero { padding: 44px 0 36px; }
  .page-hero__title { letter-spacing: -0.015em; }

  .trust-pills { gap: 0.4rem; }
  .trust-pill { font-size: var(--fs-xs); padding: 0.35rem 0.7rem; }
}

@media (max-width: 575px) {
  .card-ro { border-radius: var(--r-lg); }
  .section-title::after { width: 36px; }
}
