/* style.css - AngloMost Warszawa - Vintage Retro theme (Flexbox-only) */

/* =========================
   CSS RESET & NORMALIZE
   ========================= */
*, *::before, *::after { box-sizing: border-box; }
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video { margin: 0; padding: 0; border: 0; font: inherit; vertical-align: baseline; }
html { line-height: 1.15; -webkit-text-size-adjust: 100%; }
article, aside, footer, header, nav, section, main { display: block; }
body { line-height: 1.6; }
ol, ul { list-style: none; }
img, svg { max-width: 100%; height: auto; display: block; }
button { background: none; border: 0; cursor: pointer; font: inherit; }
a { text-decoration: none; color: inherit; }
:focus { outline: 2px dashed rgba(13,43,69,0.6); outline-offset: 2px; }

/* =========================
   THEME VARIABLES
   ========================= */
:root {
  /* Brand core */
  --color-primary: #0D2B45; /* deep navy */
  --color-secondary: #2CA58D; /* teal/green */
  --color-accent: #F6FAFF; /* light accent */
  /* Vintage palette */
  --color-cream: #F4EDE1; /* paper cream */
  --color-paper: #FBF6EC; /* warm paper */
  --color-rust: #B35C3D; /* terracotta */
  --color-mustard: #D8A013; /* mustard */
  --color-coffee: #6B4E3D; /* coffee brown */
  --color-ink: #1B1B1B; /* ink black */
  --color-olive: #6B7D53; /* muted olive */
  --color-bone: #F9F4EA; /* lighter paper */
  --color-stroke: #D9CBB6; /* vintage stroke */

  --bg-page: var(--color-bone);
  --bg-section: #FFFFFF;
  --bg-muted: var(--color-cream);

  --text-main: #2B2B2B;
  --text-muted: #5C5348;
  --text-inverse: #FFFFFF;

  --radius-xs: 6px;
  --radius-sm: 10px;
  --radius-md: 14px;

  --shadow-1: 0 2px 0 rgba(0,0,0,0.06), 0 1px 6px rgba(0,0,0,0.06);
  --shadow-2: 0 3px 0 rgba(0,0,0,0.08), 0 6px 16px rgba(0,0,0,0.10);

  --space-8: 8px;
  --space-12: 12px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-30: 30px;
  --space-32: 32px;
  --space-40: 40px;
  --space-48: 48px;
  --space-60: 60px;

  --font-display: "Trebuchet MS", Arial, sans-serif;
  --font-body: Verdana, Geneva, sans-serif;
}

/* =========================
   BASE & TYPOGRAPHY
   ========================= */
body {
  font-family: var(--font-body);
  color: var(--text-main);
  background: var(--bg-page);
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); color: var(--color-primary); line-height: 1.25; }
h1 { font-size: 32px; letter-spacing: 0.5px; }
h2 { font-size: 24px; margin-top: var(--space-8); }
h3 { font-size: 18px; color: var(--color-coffee); }
h4 { font-size: 16px; color: var(--color-coffee); }

p, li, blockquote, td, th, summary, small { font-size: 16px; color: var(--text-main); }
.subtitle, .tagline { color: var(--text-muted); font-size: 16px; }
small { font-size: 14px; color: var(--text-muted); }
strong { font-weight: 700; color: var(--color-coffee); }
em { font-style: italic; }

/* Links */
a { color: var(--color-secondary); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--color-coffee); }

/* Lists spacing */
ul, ol { display: flex; flex-direction: column; gap: 10px; margin-left: 0; }
li { position: relative; }

/* Blockquote - vintage card */
blockquote { color: var(--color-ink); padding: 16px 18px; background: var(--color-paper); border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); box-shadow: var(--shadow-1); }

/* Tables - classic lined style */
table { width: 100%; border-collapse: collapse; background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); overflow: hidden; }
th, td { text-align: left; padding: 14px; border-bottom: 1px solid var(--color-stroke); }
thead th { background: var(--color-cream); color: var(--color-coffee); font-family: var(--font-display); letter-spacing: 0.5px; }
tbody tr:nth-child(even) { background: #FAF7F0; }

/* Details / summary */
details { border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); background: #FFFFFF; box-shadow: var(--shadow-1); }
summary { padding: 14px 16px; cursor: pointer; font-family: var(--font-display); color: var(--color-primary); }
details[open] summary { background: var(--color-cream); border-bottom: 1px dashed var(--color-stroke); }
details > *:not(summary) { padding: 14px 16px; }

/* =========================
   LAYOUT
   ========================= */
.container { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 20px; display: flex; flex-direction: column; gap: var(--space-20); }
.content-wrapper { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-16); }

/* Sections */
section { margin-bottom: var(--space-60); padding: var(--space-40) 0; display: flex; }
section > .container { gap: var(--space-24); }
section:nth-of-type(odd) { background: var(--bg-section); }
section:nth-of-type(even) { background: var(--bg-muted); }

/* MANDATORY SPACING AND ALIGNMENT PATTERNS */
.section { margin-bottom: 60px; padding: 40px 20px; }
.card-container { display: flex; flex-wrap: wrap; gap: 24px; }
.card { margin-bottom: 20px; position: relative; }
.content-grid { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; }
.text-image-section { display: flex; align-items: center; gap: 30px; flex-wrap: wrap; }
.testimonial-card { display: flex; align-items: center; gap: 20px; padding: 20px; }
.feature-item { display: flex; flex-direction: column; align-items: flex-start; gap: 15px; }

/* =========================
   HEADER & NAVIGATION
   ========================= */
header { background: var(--color-cream); border-bottom: 3px solid var(--color-stroke); position: relative; z-index: 50; }
header .container { flex-direction: row; align-items: center; justify-content: space-between; gap: var(--space-16); padding-top: 12px; padding-bottom: 12px; }
header img { height: 42px; width: auto; }

.main-navigation { display: none; align-items: center; flex-wrap: wrap; gap: 14px; }
.main-navigation a { color: var(--color-primary); font-family: var(--font-display); font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; background: #FFFFFF; border: 2px solid var(--color-stroke); padding: 8px 12px; border-radius: var(--radius-xs); transition: transform .15s ease, box-shadow .15s ease, background .2s; box-shadow: var(--shadow-1); }
.main-navigation a:hover { background: var(--color-paper); transform: translateY(-1px); box-shadow: var(--shadow-2); }

.mobile-menu-toggle { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 2px solid var(--color-primary); color: var(--color-primary); border-radius: 50%; background: #FFFFFF; box-shadow: var(--shadow-1); transition: background .2s, transform .15s; }
.mobile-menu-toggle:hover { background: var(--color-cream); transform: translateY(-1px); }

/* Mobile menu overlay */
.mobile-menu { position: fixed; top: 0; right: 0; bottom: 0; left: 0; background: var(--color-paper); border-left: 4px solid var(--color-stroke); transform: translateX(100%); transition: transform .35s ease; display: flex; flex-direction: column; padding: 20px; gap: 20px; z-index: 100; }
.mobile-menu.active { transform: translateX(0); }
.mobile-menu-close { align-self: flex-end; width: 40px; height: 40px; border: 2px solid var(--color-coffee); color: var(--color-coffee); border-radius: 50%; background: #FFFFFF; box-shadow: var(--shadow-1); }
.mobile-nav { display: flex; flex-direction: column; gap: 12px; }
.mobile-nav a { padding: 14px 16px; background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); color: var(--color-primary); font-family: var(--font-display); font-size: 16px; letter-spacing: 0.03em; box-shadow: var(--shadow-1); }
.mobile-nav a:hover { background: var(--color-cream); }

/* Desktop breakpoint for nav */
@media (min-width: 992px) {
  .main-navigation { display: flex; }
  .mobile-menu-toggle { display: none; }
}

/* =========================
   HERO
   ========================= */
.hero { background: var(--color-accent); border-bottom: 3px solid var(--color-stroke); }
.hero .content-wrapper { gap: var(--space-16); }
.hero h1 { font-size: 32px; color: var(--color-primary); }
.hero .subtitle { font-size: 16px; }

@media (min-width: 768px) {
  h1 { font-size: 40px; }
  .hero h1 { font-size: 44px; }
  h2 { font-size: 28px; }
  h3 { font-size: 20px; }
}

/* =========================
   BUTTONS
   ========================= */
.btn-primary, .btn-secondary { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 18px; border-radius: var(--radius-sm); font-family: var(--font-display); font-size: 16px; letter-spacing: 0.04em; text-transform: uppercase; border: 3px solid; box-shadow: 0 3px 0 rgba(0,0,0,0.12); transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease; }
.btn-primary { background: var(--color-secondary); color: #0C1A1A; border-color: #1C8D77; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 6px 0 rgba(0,0,0,0.12); }
.btn-primary:active { transform: translateY(0); box-shadow: 0 2px 0 rgba(0,0,0,0.12); }

.btn-secondary { background: #FFFFFF; color: var(--color-primary); border-color: var(--color-primary); }
.btn-secondary:hover { background: var(--color-cream); transform: translateY(-2px); }

/* Inline pills & snippets */
.supporting-points, .supporting-badges, .contact-snippet, .contact-channels, .testimonial-rating, .rating-badge, .badge, .cta-block, .newsletter-signup, .most-helpful-badges { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; }
.supporting-points span, .supporting-badges span, .contact-snippet, .contact-channels span, .rating-badge, .badge { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: 999px; padding: 8px 12px; color: var(--color-coffee); box-shadow: var(--shadow-1); }
.supporting-points img, .supporting-badges img, .contact-snippet img, .contact-channels img, .testimonial-rating img, .rating-badge img { width: 18px; height: 18px; }
.badge strong { color: var(--color-coffee); }

/* =========================
   FEATURE / SERVICE / STATS CARDS
   ========================= */
.features-grid, .service-cards-grid, .service-highlights, .stats-grid, .pricing-teaser-tiles, .review-list { display: flex; flex-wrap: wrap; gap: 20px; }

/* Generic card look for inner items */
.features-grid > div, .service-cards-grid > div, .service-highlights > div, .pricing-teaser-tiles > div, .case-study, .outcome-highlights, .reviews-filter-controls { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-md); padding: 18px; box-shadow: var(--shadow-1); display: flex; flex-direction: column; gap: 10px; }

.stats-grid > div { background: var(--color-paper); border: 2px dashed var(--color-stroke); border-radius: var(--radius-md); padding: 18px; box-shadow: var(--shadow-1); color: var(--color-coffee); display: flex; flex-direction: column; gap: 6px; }
.kpi { font-family: var(--font-display); font-size: 28px; color: var(--color-primary); }

/* Testimonials: light backgrounds and dark text for readability */
.testimonial-card { background: #FFF8E6; border: 2px solid #EAD9B7; border-radius: var(--radius-md); box-shadow: var(--shadow-1); color: #2B2B2B; }
.testimonial-card footer { color: var(--color-coffee); }
.testimonial-rating { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); padding: 8px 12px; color: var(--color-ink); }

/* Lists with vintage bullets */
.value-propositions, .microproof, .service-categories { gap: 8px; }
.value-propositions li, .microproof li, .service-categories li { padding-left: 28px; }
.value-propositions li::before, .microproof li::before, .service-categories li::before { content: "◆"; position: absolute; left: 8px; top: 0; color: var(--color-mustard); font-size: 14px; }

/* Stepper overview */
.stepper-overview { counter-reset: steps; gap: 12px; }
.stepper-overview li { display: flex; align-items: center; gap: 10px; }
.stepper-overview li::before { counter-increment: steps; content: counter(steps); display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: var(--color-cream); border: 2px solid var(--color-stroke); color: var(--color-coffee); font-weight: bold; }

/* CTA sections */
.cta { background: var(--color-primary); color: var(--text-inverse); border-top: 4px solid var(--color-stroke); border-bottom: 4px solid var(--color-stroke); }
.cta a { color: var(--text-inverse); text-decoration: none; }
.cta .btn-primary { background: var(--color-mustard); border-color: #B98B0F; color: #3B2E00; }
.cta .btn-secondary { background: #FFFFFF; border-color: #FFFFFF; color: var(--color-primary); }

/* Pricing auxiliary */
.disclaimer { color: var(--text-muted); font-style: italic; }
.corporate-offer { background: var(--color-paper); border: 2px dashed var(--color-stroke); border-radius: var(--radius-sm); padding: 12px 14px; color: var(--color-coffee); }
.support-contact { margin-top: 8px; color: var(--color-coffee); }

/* Progress indicator, consent, privacy blocks */
.progress-indicator, .consent-block, .privacy-note { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); padding: 12px 14px; display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow-1); color: var(--color-coffee); }

/* Reviews */
.reviews-filter-controls { font-family: var(--font-display); color: var(--color-coffee); }
.review-list { margin-top: 4px; }
.review-list li { width: 100%; }

.rating-breakdown { color: var(--color-coffee); background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); padding: 10px 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.most-helpful-badges span { background: var(--color-cream); border: 2px solid var(--color-stroke); border-radius: 999px; padding: 6px 10px; color: var(--color-coffee); }

/* Contact prompts */
.contact-prompt { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); padding: 12px 14px; color: var(--color-coffee); box-shadow: var(--shadow-1); }

/* Footer */
footer { background: var(--color-cream); border-top: 3px solid var(--color-stroke); }
footer .container { flex-direction: row; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-16); padding-top: 18px; padding-bottom: 18px; }
.footer-navigation, .legal-links, .social-links, .brand-signature, .newsletter-signup { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; }
.footer-navigation a, .legal-links a { background: #FFFFFF; border: 2px solid var(--color-stroke); padding: 6px 10px; border-radius: var(--radius-xs); color: var(--color-primary); font-size: 14px; box-shadow: var(--shadow-1); }
.brand-signature img { height: 30px; width: auto; }
.newsletter-signup { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); padding: 10px 12px; box-shadow: var(--shadow-1); }
.map-disclaimer { color: var(--text-muted); font-size: 14px; }

/* =========================
   RESPONSIVE RULES
   ========================= */
@media (max-width: 768px) {
  .text-image-section { flex-direction: column; }
}

@media (min-width: 768px) {
  .features-grid > div, .service-cards-grid > div, .service-highlights > div, .pricing-teaser-tiles > div, .review-list li > div { flex: 1 1 calc(50% - 20px); }
  .stats-grid > div { flex: 1 1 calc(25% - 20px); }
}

@media (min-width: 1024px) {
  .features-grid > div, .service-cards-grid > div, .service-highlights > div { flex: 1 1 calc(25% - 20px); }
}

/* =========================
   FORMS (placeholders for lists-as-forms)
   ========================= */
/* The HTML uses lists to represent form fields; style them consistently */
section ul li { background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: var(--radius-xs); padding: 10px 12px; }

/* =========================
   UTILITIES
   ========================= */
.hr { height: 2px; background: var(--color-stroke); width: 100%; }
.muted { color: var(--text-muted); }
.pill { background: var(--color-cream); border: 2px solid var(--color-stroke); border-radius: 999px; padding: 6px 10px; }

/* =========================
   MOBILE MENU ANIMATIONS
   ========================= */
@keyframes slideInMenu { from { transform: translateX(100%); } to { transform: translateX(0); } }
@keyframes slideOutMenu { from { transform: translateX(0); } to { transform: translateX(100%); } }
.mobile-menu.active { animation: slideInMenu .35s ease; }

/* =========================
   COOKIE CONSENT BANNER
   ========================= */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; background: #FFFFFF; border-top: 3px solid var(--color-stroke); box-shadow: 0 -6px 16px rgba(0,0,0,0.08); z-index: 200; display: flex; }
.cookie-banner .container { flex-direction: row; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 20px; }
.cookie-banner .message { display: flex; flex: 1; flex-direction: column; gap: 6px; color: var(--color-coffee); }
.cookie-buttons { display: flex; gap: 10px; flex-wrap: wrap; }
.cookie-btn { padding: 10px 14px; border-radius: var(--radius-sm); border: 2px solid var(--color-stroke); font-family: var(--font-display); letter-spacing: 0.04em; box-shadow: var(--shadow-1); }
.cookie-accept { background: var(--color-secondary); color: #0C1A1A; border-color: #1C8D77; }
.cookie-reject { background: #FFFFFF; color: var(--color-primary); border-color: var(--color-primary); }
.cookie-settings { background: var(--color-cream); color: var(--color-coffee); }

/* Cookie modal */
.cookie-modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.45); opacity: 0; pointer-events: none; transition: opacity .25s ease; display: flex; align-items: center; justify-content: center; z-index: 210; }
.cookie-modal-backdrop.active { opacity: 1; pointer-events: auto; }
.cookie-modal { background: #FFFFFF; border: 3px solid var(--color-stroke); border-radius: var(--radius-md); width: min(680px, 92%); display: flex; flex-direction: column; gap: 14px; padding: 18px; box-shadow: var(--shadow-2); }
.cookie-modal header { display: flex; align-items: center; justify-content: space-between; }
.cookie-modal .categories { display: flex; flex-direction: column; gap: 10px; }
.cookie-toggle { display: flex; align-items: center; justify-content: space-between; gap: 10px; background: var(--color-paper); border: 2px solid var(--color-stroke); border-radius: var(--radius-sm); padding: 10px 12px; }
.cookie-toggle .label { color: var(--color-coffee); }
.toggle { width: 46px; height: 26px; background: #DDD3C1; border: 2px solid var(--color-stroke); border-radius: 999px; position: relative; display: inline-flex; align-items: center; }
.toggle::after { content: ""; width: 18px; height: 18px; background: #FFFFFF; border: 2px solid var(--color-stroke); border-radius: 50%; transform: translateX(2px); transition: transform .2s ease; }
.toggle.on { background: var(--color-secondary); }
.toggle.on::after { transform: translateX(20px); }
.cookie-modal footer { display: flex; align-items: center; justify-content: flex-end; gap: 10px; }

/* =========================
   ACCESSIBILITY & INTERACTIONS
   ========================= */
button:focus, .btn-primary:focus, .btn-secondary:focus, a:focus { outline: 2px dashed var(--color-mustard); outline-offset: 2px; }

/* =========================
   PAGE-SPECIFIC TWEAKS
   ========================= */
/* Hero extras */
.hero .value-propositions { margin-top: 6px; }
.hero .btn-primary, .hero .btn-secondary { margin-top: 4px; }

/* Index: badge row */
.badge { padding: 8px 12px; }

/* Opinions page */
.rating-badge { font-weight: 700; }
.case-study { color: var(--color-coffee); }
.outcome-highlights ul { display: flex; flex-direction: column; gap: 8px; }

/* Contact page */
#kontakt-skrot p, .privacy-note { display: flex; align-items: center; gap: 8px; }

/* Tables in policy pages */
.legal-links { gap: 10px; }

/* =========================
   CARD HOVER EFFECTS
   ========================= */
.features-grid > div:hover, .service-cards-grid > div:hover, .service-highlights > div:hover, .stats-grid > div:hover, .pricing-teaser-tiles > div:hover, .review-list li > div:hover, .contact-prompt:hover { transform: translateY(-2px); transition: transform .15s ease, box-shadow .15s ease; box-shadow: var(--shadow-2); }

/* =========================
   ENSURE MINIMUM SPACING BETWEEN CARDS
   ========================= */
.features-grid > div, .service-cards-grid > div, .service-highlights > div, .stats-grid > div, .pricing-teaser-tiles > div, .review-list li > div, .testimonial-card { margin-bottom: 20px; }

/* =========================
   PRINT-LIKE HEADERS FOR RETRO FEEL
   ========================= */
h1, h2 { text-shadow: 0 1px 0 rgba(255,255,255,0.6); letter-spacing: 0.02em; }

/* =========================
   SAFETY: NO OVERLAPS
   ========================= */
section, .features-grid, .service-cards-grid, .stats-grid, .pricing-teaser-tiles, .review-list { gap: 20px; }

/* =========================
   END
   ========================= */
