/*
Theme Name: SORSTE
Theme URI: https://www.sorste.ro
Author: SORSTE
Description: Temă custom SORSTE — croitorie pentru case de modă & proiecte europene. Editorial, photo-light. Conținut editabil prin ACF + Custom Post Types (Proiecte, Anunțuri).
Version: 0.3.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: sorste
*/

/* ============================================================
   SORSTE — schelet site (pe baza mockup-ului)
   Sistem de design comun
   ============================================================ */


:root{
  /* Paletă aprobată */
  --bg:        #F4EFE6;   /* Sand — fundal */
  --bg-panel:  #EAE3D4;   /* placeholder-uri foto */
  --ink:       #1A1A1A;   /* Negru — text principal */
  --ink-soft:  #4d4a45;   /* paragrafe */
  --muted:     #9c958a;   /* etichete, meta */
  --line:      #ddd6c8;   /* linii subtiri */
  --accent:    #E26A5C;   /* Coral */
  --dark:      #1A1A1A;   /* sectiuni inchise */
  --on-dark:   #F4EFE6;
  --on-dark-muted: rgba(244,239,230,.45);
  --on-dark-line:  rgba(244,239,230,.15);

  /* Tipografie aprobată */
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Inter", system-ui, sans-serif;

  --maxw: 1280px;
  --pad: 48px;
  --radius: 2px;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

/* ---------- Etichete / eyebrow ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ---------- Tipografie display ---------- */
.display{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.06;
  letter-spacing:0;
  color:var(--ink);
}
.display em{ font-style:italic; font-weight:500; }
h1.display{ font-size:clamp(2.8rem, 5.6vw, 4.6rem); }
h2.display{ font-size:clamp(2.1rem, 3.8vw, 3.1rem); }
h3.display{ font-size:clamp(1.4rem, 2.1vw, 1.75rem); }

.lead{
  font-size:1.02rem;
  color:var(--ink-soft);
  max-width:46ch;
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid var(--line);
}
.topbar .container{
  display:flex; align-items:center; gap:32px;
  height:72px;
}
.logo{
  font-family:var(--sans);
  font-weight:800;
  font-size:1.45rem;
  letter-spacing:-0.04em;
  color:var(--ink);
}
.logo .dot{ color:var(--accent); }

.nav{
  display:flex; gap:34px; margin-left:auto;
}
.nav a{
  font-size:12px; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink);
  padding:4px 0; position:relative;
  transition:color .2s;
}
.nav a:hover{ color:var(--accent); }
.nav a.active{ border-bottom:1.5px solid var(--ink); }

.lang{
  font-size:12px; font-weight:600; letter-spacing:.12em;
  color:var(--muted);
}
.lang strong{ color:var(--ink); font-weight:700; }

.menu-toggle{ display:none; background:none; border:0; cursor:pointer; font-size:13px;
  font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); }

/* ============================================================
   BUTOANE
   ============================================================ */
.btn, .btn-outline{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-size:12px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase;
  padding:15px 26px; border-radius:var(--radius);
  cursor:pointer; transition:all .2s; border:1px solid var(--ink);
}
.btn{ background:var(--ink); color:var(--bg); }
.btn:hover{ background:transparent; color:var(--ink); }
.btn-outline{ background:transparent; color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:var(--bg); }
.btn-accent{ background:var(--accent); border-color:var(--accent); color:#fff; }
.btn-accent:hover{ background:transparent; color:var(--accent); }

/* link-uri cu sageata */
.arrow-link{
  font-size:12px; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink);
  border-bottom:1px solid var(--ink); padding-bottom:3px;
  transition:color .2s, border-color .2s;
}
.arrow-link:hover{ color:var(--accent); border-color:var(--accent); }

/* ============================================================
   PLACEHOLDER FOTO  (crosshatch)
   ============================================================ */
.ph{
  position:relative;
  background:var(--bg-panel);
  background-image:
    repeating-linear-gradient(45deg,
      rgba(0,0,0,.035) 0, rgba(0,0,0,.035) 1px,
      transparent 1px, transparent 9px);
  border:1px solid var(--line);
}
.ph::after{
  content:attr(data-label);
  position:absolute; left:16px; bottom:14px;
  font-size:10px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted);
}
.ph.square{ aspect-ratio:1/1; }
.ph.tall{ aspect-ratio:3/4; }

/* ============================================================
   SECTIUNI
   ============================================================ */
section{ padding-block:clamp(56px, 8vw, 110px); }
.section-tight{ padding-block:clamp(40px,5vw,64px); }

.dark-section{ background:var(--dark); color:var(--on-dark); }
.dark-section .display{ color:var(--on-dark); }
.dark-section .lead{ color:var(--on-dark-muted); }
.dark-section .eyebrow{ color:var(--on-dark-muted); }

/* ---------- HERO ---------- */
.hero{ padding-block:clamp(40px,6vw,80px); }
.hero-grid{
  display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center;
}
.hero-grid .ph{ min-height:520px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.hero h1.display{ margin:18px 0 26px; }

/* ---------- mini-stats (sub hero) ---------- */
.ministats{ display:flex; gap:56px; margin-top:40px; padding-top:30px;
  border-top:1px solid var(--line); }
.ministat .num{ font-family:var(--serif); font-size:2rem; line-height:1; }
.ministat .lbl{ font-size:12px; color:var(--muted); margin-top:6px; }

/* ============================================================
   BANDA PARTENERI
   ============================================================ */
.partners{ background:var(--bg-panel); border-top:1px solid var(--line);
  border-bottom:1px solid var(--line); }
.partners .container{ padding-block:34px; }
.partners .eyebrow{ text-align:center; display:block; margin-bottom:22px; }
.partners-row{ display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.partners-row span{ font-family:var(--serif); font-size:1.02rem; color:var(--ink);
  letter-spacing:.02em; opacity:.78; }

/* ============================================================
   GRID DE CARDURI NUMEROTATE (capabilitati / transparenta)
   ============================================================ */
.section-head{ text-align:center; margin-bottom:64px; }
.section-head .eyebrow{ display:block; margin-bottom:14px; }

.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:48px 56px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }

.numcard .n{ font-family:var(--serif); font-size:1.5rem; color:var(--accent);
  display:block; margin-bottom:14px; }
.numcard h3{ font-family:var(--serif); font-size:1.25rem; font-weight:400;
  margin-bottom:10px; }
.numcard p{ color:var(--ink-soft); font-size:.95rem; }

/* card cu border (transparenta corporativa) */
.boxcard{ border:1px solid var(--line); padding:30px 28px; border-radius:var(--radius);
  background:color-mix(in srgb,var(--bg) 60%, #fff); transition:border-color .2s; }
.boxcard:hover{ border-color:var(--ink); }
.boxcard .n{ font-family:var(--serif); color:var(--accent); font-size:.95rem; }
.boxcard h3{ font-family:var(--serif); font-weight:400; font-size:1.25rem; margin:6px 0 10px; }
.boxcard p{ color:var(--ink-soft); font-size:.92rem; margin-bottom:16px; }
.tags{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.tag{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);
  background:var(--bg-panel); padding:5px 10px; border-radius:20px; }

/* ============================================================
   FLUX TEHNOLOGIC (rânduri numerotate)
   ============================================================ */
.flow-row{ display:grid; grid-template-columns:48px 200px 1fr; gap:24px;
  padding:18px 0; border-bottom:1px solid var(--line); align-items:baseline; }
.flow-row .n{ font-family:var(--serif); color:var(--accent); }
.flow-row .t{ font-weight:600; }
.flow-row .d{ color:var(--ink-soft); }

/* listă cheie-valoare (sistem calitate / proiect meta) */
.kv{ display:grid; grid-template-columns:160px 1fr; gap:6px 18px;
  padding:14px 0; border-bottom:1px solid var(--line); }
.kv dt{ font-weight:600; }
.kv dd{ color:var(--ink-soft); }

/* ============================================================
   STATS (banda mare numere)
   ============================================================ */
.statband{ display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
.statband .num{ font-family:var(--serif); font-size:clamp(2.4rem,4vw,3.4rem); line-height:1; }
.statband .lbl{ font-size:13px; color:var(--muted); margin-top:10px; }

/* ============================================================
   CITAT
   ============================================================ */
.quote{ text-align:center; max-width:60ch; margin:0 auto; }
.quote p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,2.6vw,2rem);
  line-height:1.35; }
.quote .by{ display:block; margin-top:26px; font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--on-dark-muted); }

/* ============================================================
   TIMELINE (istoric)
   ============================================================ */
.timeline{ display:grid; grid-template-columns:repeat(5,1fr); gap:24px;
  border-top:1px solid var(--line); padding-top:28px; }
.tl .dot{ width:10px; height:10px; border-radius:50%; background:var(--ink);
  margin-bottom:18px; }
.tl:nth-child(odd) .dot{ background:var(--accent); }
.tl .year{ font-family:var(--serif); font-size:1.6rem; }
.tl p{ font-size:.85rem; color:var(--ink-soft); margin-top:8px; }

/* ============================================================
   PROIECTE — carduri
   ============================================================ */
.filters{ display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding-block:22px; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  font-size:12px; }
.filters .lbl{ letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
  margin-right:6px; }
.chip{ border:1px solid var(--line); border-radius:30px; padding:7px 16px;
  font-weight:600; letter-spacing:.04em; cursor:pointer; background:transparent;
  font-family:var(--sans); transition:all .2s; }
.chip.on{ background:var(--ink); color:var(--bg); border-color:var(--ink); }
.filters .count{ margin-left:auto; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); }

.subhead{ display:flex; justify-content:space-between; align-items:baseline;
  margin:48px 0 24px; }
.subhead h2{ font-family:var(--serif); font-weight:400; font-size:1.7rem; }
.subhead .meta{ font-size:12px; color:var(--muted); letter-spacing:.06em; }

.proj-active{ border-left:3px solid var(--accent); padding:26px 30px;
  background:var(--bg-panel); }
.proj-active .status{ font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); font-weight:600; }
.proj-active h3{ font-family:var(--serif); font-weight:400; font-size:1.5rem; margin:8px 0 4px; }
.proj-active .smis{ font-size:12px; color:var(--muted); margin-bottom:18px; }
.proj-active p{ color:var(--ink-soft); font-size:.92rem; margin:18px 0; }
.proj-active .foot{ display:flex; gap:18px; align-items:center; padding-top:16px;
  border-top:1px solid var(--line); }

.proj-done{ border:1px solid var(--line); padding:22px 24px; border-radius:var(--radius);
  background:color-mix(in srgb,var(--bg) 50%, #fff); }
.proj-done .status{ font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); font-weight:600; }
.proj-done .status::before{ content:"●"; color:var(--muted); margin-right:7px; font-size:8px; }
.proj-done h3{ font-family:var(--serif); font-weight:400; font-size:1.18rem; margin:8px 0 2px; }
.proj-done .smis{ font-size:12px; color:var(--muted); }
.proj-done .info{ font-size:12px; color:var(--ink-soft); margin:14px 0; }

/* ============================================================
   FORMULAR CONTACT
   ============================================================ */
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); margin-bottom:8px; font-weight:600; }
.field input, .field textarea, .field select{
  width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:var(--radius);
  background:#fff; font-family:var(--sans); font-size:.95rem; color:var(--ink); }
.field textarea{ min-height:140px; resize:vertical; }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none;
  border-color:var(--ink); }

/* ============================================================
   CTA pe fundal inchis
   ============================================================ */
.cta{ text-align:center; }
.cta .eyebrow{ display:block; margin-bottom:18px; }
.cta h2{ font-family:var(--serif); font-weight:400; margin-bottom:14px;
  font-size:clamp(1.8rem,3vw,2.4rem); }
.cta p{ color:var(--on-dark-muted); margin-bottom:30px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--dark); color:var(--on-dark); padding-block:64px 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:48px; }
.footer-grid .logo{ color:var(--on-dark); margin-bottom:18px; }
.footer-grid address{ font-style:normal; font-size:.9rem; color:var(--on-dark-muted);
  line-height:1.9; }
.footer-col h4{ font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--on-dark-muted); margin-bottom:16px; font-weight:600; }
.footer-col a{ display:block; font-size:.92rem; color:var(--on-dark); padding:5px 0;
  opacity:.82; transition:opacity .2s, color .2s; }
.footer-col a:hover{ opacity:1; color:var(--accent); }
.footer-bottom{ border-top:1px solid var(--on-dark-line); padding-block:22px;
  display:flex; justify-content:space-between; font-size:.8rem; color:var(--on-dark-muted);
  flex-wrap:wrap; gap:10px; }

/* bara meta de pagina (subsol) */
.metabar{ border-top:1px solid var(--line); }
.metabar .container{ display:flex; justify-content:space-between;
  padding-block:18px; font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); }

/* ============================================================
   UTIL
   ============================================================ */
.divider{ height:1px; background:var(--line); border:0; margin-block:40px; }
.mt-s{ margin-top:24px; } .mt-m{ margin-top:40px; } .mb-m{ margin-bottom:40px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  :root{ --pad:28px; }
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-grid .ph{ min-height:340px; }
  .grid-3{ grid-template-columns:repeat(2,1fr); }
  .statband{ grid-template-columns:repeat(2,1fr); gap:36px 24px; }
  .timeline{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  .nav{ display:none; }
  .menu-toggle{ display:inline-block; margin-left:auto; }
  .grid-3, .grid-2{ grid-template-columns:1fr; }
  .ministats{ flex-wrap:wrap; gap:24px; }
  .statband{ grid-template-columns:1fr 1fr; }
  .timeline{ grid-template-columns:1fr; }
  .flow-row{ grid-template-columns:36px 1fr; }
  .flow-row .d{ grid-column:2; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
}

/* ============================================================
   Ajustări pentru Cormorant Garamond (serif mai delicat)
   ============================================================ */
.numcard h3, .boxcard h3, .proj-active h3, .proj-done h3,
.subhead h2, .cta h2, .ph + *, .statband .num, .ministat .num,
.flow-row .n, .numcard .n, .boxcard .n, .tl .year{ font-weight:600; }
.quote p{ font-weight:500; }
/* logo: geometric, gros (Inter 800) */
.logo{ font-weight:800; letter-spacing:-0.05em; }
/* numerele mari de statistici beneficiază de puțin mai mult corp */
.statband .num{ font-size:clamp(2.8rem,4.4vw,3.8rem); }

/* alias: WordPress marchează item-ul curent cu .current-menu-item */
.nav li.current-menu-item > a,
.nav .current_page_item > a{ border-bottom:1.5px solid var(--ink); color:var(--ink); }
.nav ul{ list-style:none; display:flex; gap:34px; margin:0; padding:0; }

/* ============================================================
   PHOTO-LIGHT — heroes fără fotografii (design tipografic)
   ============================================================ */
.hero-lead{ padding-block:clamp(64px,10vw,140px); }
.hero-lead .hero-title{ max-width:20ch; margin:22px 0 28px; }
.hero-lead .lead-wide{ max-width:62ch; }
.hero-rule{ width:64px; height:3px; background:var(--accent); border:0; margin:0 0 30px; }
.hero-meta{ display:flex; gap:48px; margin-top:44px; padding-top:28px;
  border-top:1px solid var(--line); flex-wrap:wrap; }
.hero-meta .num{ font-family:var(--serif); font-weight:600; font-size:1.9rem; line-height:1; }
.hero-meta .lbl{ font-size:12px; color:var(--muted); margin-top:6px; max-width:22ch; }

/* flux tehnologic photo-light: intro + listă pe toată lățimea */
.flow-intro{ max-width:60ch; margin-bottom:40px; }

@media (max-width:640px){
  .hero-meta{ gap:24px; }
}

/* === Meniu mobil vertical (deschis cu butonul MENIU) === */
@media (max-width:860px){
  .nav{ display:none; }
  .menu-toggle{ display:inline-block; margin-left:auto; }
  .nav.nav-open{
    display:flex; position:absolute; top:72px; left:0; right:0;
    flex-direction:column; gap:4px;
    background:var(--bg);
    border-top:1px solid var(--line); border-bottom:1px solid var(--line);
    padding:16px 28px 22px; box-shadow:0 16px 30px rgba(0,0,0,.06);
  }
  .nav.nav-open ul{ flex-direction:column; gap:0; width:100%; }
  .nav.nav-open a{ display:block; padding:12px 0; border-bottom:1px solid var(--line); font-size:14px; }
}
