/* ============================================================================
   TRAINIC — "Engineered Warmth"
   Construcții din lemn și metal. Industrial-craft + editorial minimal.
   Display: Bricolage Grotesque · Text: Instrument Sans · Tehnic: JetBrains Mono
   ========================================================================== */

:root{
  /* palette — timber + steel + linen */
  --paper:#F4EFE6;        /* linen base */
  --paper-2:#ECE4D6;      /* deeper linen */
  --card:#FBF8F2;         /* lifted surface */
  --ink:#191814;          /* charcoal steel (text / dark band) */
  --ink-2:#211F1A;
  --steel:#6E695E;        /* secondary text */
  --steel-2:#8C877A;
  --line:rgba(25,24,20,.13);
  --line-2:rgba(25,24,20,.07);
  --timber:#B86A2E;       /* primary accent — oak/ochre */
  --timber-700:#94521F;
  --timber-ink:#5E3514;
  --amber:#E0A45C;        /* highlight on dark */
  --paper-on-dark:#EDE6D9;
  --steel-on-dark:#A39A88;
  --ok:#3E7C50;
  --warn:#C0492B;
  --wa:#25D366;

  /* edit-mode aliases (page-editor.js expects these roles) */
  --cer:var(--timber); --cer-700:var(--timber-700); --cer-50:rgba(184,106,46,.10);

  --display:'Bricolage Grotesque',Georgia,serif;
  --sans:'Instrument Sans',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --r-sm:9px; --r:15px; --r-lg:24px; --r-xl:30px;
  --shadow-sm:0 1px 2px rgba(25,24,20,.06),0 4px 14px -8px rgba(25,24,20,.18);
  --shadow:0 12px 30px -16px rgba(25,24,20,.30);
  --shadow-lg:0 30px 70px -30px rgba(25,24,20,.45);
  --maxw:1240px; --gut:clamp(18px,4.4vw,56px);
  --ease:cubic-bezier(.22,.61,.32,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:clamp(15.5px,.5vw + 14.5px,17px);line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* faint blueprint grid atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    linear-gradient(var(--line-2) 1px,transparent 1px),
    linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 0,#000,transparent 78%);
          mask-image:radial-gradient(120% 90% at 50% 0,#000,transparent 78%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--timber);color:#fff}

/* ---------- layout primitives ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
section{position:relative}
.section{padding-block:clamp(64px,9vw,120px)}
.section-head{max-width:680px;margin-bottom:clamp(34px,5vw,58px)}
.eyebrow{
  font-family:var(--mono);font-size:.74rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--timber-700);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--timber);display:inline-block}
.num{font-family:var(--mono);font-size:.78rem;color:var(--steel-2);letter-spacing:.05em}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.04;letter-spacing:-.022em;margin:0}
h2{font-size:clamp(2rem,4.4vw,3.3rem);margin-top:.5rem}
h3{font-size:clamp(1.28rem,2vw,1.6rem);letter-spacing:-.015em}
.lead{font-size:clamp(1.04rem,1.3vw,1.22rem);color:var(--steel);margin-top:1rem;line-height:1.58}
p{margin:0 0 1rem}
.ital{font-style:italic;color:var(--timber-700)}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:.92em 1.5em;border-radius:999px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);font-weight:600;font-size:.96rem;
  cursor:pointer;transition:transform .2s var(--ease),box-shadow .25s,background .2s,color .2s,border-color .2s;
  white-space:nowrap;letter-spacing:-.01em;
}
.btn svg{width:1.15em;height:1.15em}
.btn:hover{transform:translateY(-2px)}
.btn-primary{--bg:var(--timber);--fg:#fff;box-shadow:0 10px 26px -12px rgba(184,106,46,.8)}
.btn-primary:hover{--bg:var(--timber-700);box-shadow:0 16px 34px -14px rgba(184,106,46,.85)}
.btn-ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line);}
.btn-ghost:hover{--bg:rgba(25,24,20,.04);border-color:var(--ink)}
.btn-dark{--bg:var(--ink);--fg:#fff}.btn-dark:hover{--bg:#000}
.btn-wa{--bg:var(--wa);--fg:#08311a}.btn-wa:hover{--bg:#1fbf5b}
.btn-lg{padding:1.05em 1.8em;font-size:1.02rem}
.btn-block{width:100%}

/* ============================================================================
   HEADER
   ========================================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s,border-color .3s}
.site-header::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:transparent;transition:background .3s}
.site-header.scrolled{background:rgba(244,239,230,.86);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2)}
.site-header.scrolled::after{background:var(--line)}
.nav{display:flex;align-items:center;gap:22px;height:74px}
.brand{display:inline-flex;align-items:center;gap:11px;font-family:var(--display);font-weight:700;font-size:1.32rem;letter-spacing:-.03em}
.brand .ibeam{width:30px;height:30px;flex:0 0 auto}
.brand b{font-weight:700}
.nav-links{display:flex;gap:4px;margin-inline:auto}
.nav-links a{font-size:.94rem;font-weight:500;color:var(--ink);padding:.5em .8em;border-radius:8px;opacity:.82;transition:opacity .2s,background .2s}
.nav-links a:hover{opacity:1;background:rgba(25,24,20,.05)}
.nav-cta{display:flex;align-items:center;gap:12px}
.phone-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-weight:600;font-size:.9rem;letter-spacing:-.01em}
.phone-link svg{width:17px;height:17px;color:var(--timber)}
.phone-link:hover{color:var(--timber-700)}
.hdr-ic{display:none}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:var(--card);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-toggle span{width:19px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--paper);transform:translateY(-100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;visibility:hidden}
.mobile-menu.show{transform:translateY(0);visibility:visible}
.mm-bar{display:flex;align-items:center;justify-content:space-between;height:74px;padding-inline:var(--gut)}
.mm-close{width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:var(--card);position:relative;cursor:pointer}
.mm-close::before,.mm-close::after{content:"";position:absolute;inset:50% 12px auto;height:2px;background:var(--ink);top:50%}
.mm-close::before{transform:rotate(45deg)}.mm-close::after{transform:rotate(-45deg)}
.mm-links{display:flex;flex-direction:column;padding:14px var(--gut) 40px;gap:2px;overflow:auto}
.mm-links a{display:flex;align-items:center;gap:16px;padding:18px 4px;border-bottom:1px solid var(--line-2);font-family:var(--display);font-size:1.55rem;font-weight:600}
.mm-links a .mm-n{font-family:var(--mono);font-size:.8rem;color:var(--timber);font-weight:600}
.mm-foot{margin-top:auto;padding:22px var(--gut) calc(22px + env(safe-area-inset-bottom));border-top:1px solid var(--line);display:flex;gap:12px;flex-wrap:wrap}
html.menu-open{overflow:hidden}

/* ============================================================================
   HERO
   ========================================================================== */
.hero{padding-top:128px;padding-bottom:clamp(48px,7vw,84px);overflow:clip}
.hero-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:clamp(28px,4vw,60px);align-items:center}
.hero-copy{max-width:600px}
.hero h1{font-size:clamp(2.7rem,6.6vw,5rem);font-weight:800;letter-spacing:-.035em;margin-top:1.1rem}
.hero h1 .line2{color:var(--timber)}
.hero .lead{max-width:48ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:1.9rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:8px 22px;margin-top:1.9rem;font-family:var(--mono);font-size:.79rem;color:var(--steel);letter-spacing:-.01em}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust span::before{content:"";width:7px;height:7px;background:var(--timber);transform:rotate(45deg);flex:0 0 auto}

.hero-media{position:relative}
.hero-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3.05;background:var(--ink)}
.hero-frame img{width:100%;height:100%;object-fit:cover}
.hero-frame::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(160deg,transparent 55%,rgba(20,16,10,.42))}
/* dimension ticks (blueprint flourish) */
.hero-media .tick{position:absolute;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--steel-2);text-transform:uppercase}
.hero-media .tick.t-top{top:-26px;left:6px;display:flex;align-items:center;gap:9px}
.hero-media .tick.t-top::after{content:"";width:clamp(40px,12vw,150px);height:1px;background:var(--line)}
/* floating spec plate */
.spec-plate{position:absolute;right:-18px;bottom:-22px;background:var(--ink);color:var(--paper-on-dark);border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-lg);display:grid;gap:9px;min-width:212px}
.spec-plate .sp-row{display:flex;align-items:baseline;justify-content:space-between;gap:18px;font-family:var(--mono);font-size:.74rem;letter-spacing:.02em}
.spec-plate .sp-row span:first-child{color:var(--steel-on-dark)}
.spec-plate .sp-row b{color:#fff;font-weight:600}
.spec-plate .sp-row .hot{color:var(--amber)}
.spec-plate .sp-divider{height:1px;background:rgba(255,255,255,.12)}

/* ============================================================================
   TRUST STRIP
   ========================================================================== */
.strip{border-block:1px solid var(--line);background:var(--paper-2)}
.strip-row{display:flex;flex-wrap:wrap;align-items:center;gap:14px 0;justify-content:space-between;padding-block:18px}
.strip-item{display:inline-flex;align-items:center;gap:11px;font-family:var(--mono);font-size:.82rem;font-weight:500;letter-spacing:-.01em;color:var(--ink);padding-inline:clamp(8px,1.6vw,20px)}
.strip-item svg{width:18px;height:18px;color:var(--timber);flex:0 0 auto}

/* ============================================================================
   SERVICES (01)
   ========================================================================== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.8vw,24px)}
.card{position:relative;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s,border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card-img{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--ink)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card-img img{transform:scale(1.06)}
.card-img .c-num{position:absolute;top:12px;left:13px;font-family:var(--mono);font-size:.72rem;font-weight:600;color:#fff;background:rgba(20,16,10,.5);backdrop-filter:blur(4px);padding:4px 9px;border-radius:7px;letter-spacing:.04em}
.card-body{padding:20px 21px 22px;display:flex;flex-direction:column;flex:1}
.card-body h3{margin-bottom:.45rem}
.card-body p{font-size:.93rem;color:var(--steel);margin-bottom:1rem;line-height:1.55}
.card-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}
.ctag{font-family:var(--mono);font-size:.69rem;letter-spacing:.02em;color:var(--timber-ink);background:rgba(184,106,46,.10);border:1px solid rgba(184,106,46,.20);padding:3px 9px;border-radius:7px}
.card-meta{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line-2)}
.price{font-family:var(--mono);font-size:.9rem;font-weight:600;color:var(--ink)}
.price small{color:var(--steel-2);font-weight:400}
.card-arrow{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--timber);transition:background .25s,color .25s,transform .25s}
.card:hover .card-arrow{background:var(--timber);color:#fff;transform:rotate(-45deg)}
.card-arrow svg{width:16px;height:16px}
.card-cta{margin-top:auto;display:inline-flex;align-items:center;gap:9px;padding-top:15px;border-top:1px solid var(--line-2);font-family:var(--mono);font-size:.8rem;font-weight:600;letter-spacing:-.01em;color:var(--timber-700);transition:gap .25s,color .25s}
.card-cta svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.card:hover .card-cta{color:var(--timber)}
.card:hover .card-cta svg{transform:translateX(5px)}

/* ============================================================================
   WORK / GALLERY (02)
   ========================================================================== */
.work-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:20px}
.filterbar{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.filterbar button{font-family:var(--mono);font-size:.78rem;font-weight:500;letter-spacing:-.01em;color:var(--steel);background:transparent;border:1px solid var(--line);padding:.55em 1.05em;border-radius:999px;cursor:pointer;transition:.22s}
.filterbar button:hover{border-color:var(--ink);color:var(--ink)}
.filterbar button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.gallery{display:grid;gap:13px;grid-template-columns:repeat(2,1fr);grid-auto-rows:165px;grid-auto-flow:dense;margin-top:30px}
@media (min-width:720px){.gallery{grid-template-columns:repeat(3,1fr);grid-auto-rows:200px}}
@media (min-width:1040px){.gallery{grid-template-columns:repeat(4,1fr);grid-auto-rows:215px}}
.shot{position:relative;margin:0;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--ink);box-shadow:var(--shadow-sm);transition:opacity .35s,transform .35s}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.shot:hover img{transform:scale(1.06)}
.shot figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 13px 11px;font-size:.78rem;font-weight:500;color:#fff;background:linear-gradient(transparent,rgba(20,16,10,.82));opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.shot:hover figcaption{opacity:1;transform:none}
.shot.g-big{grid-column:span 2;grid-row:span 2}
.shot.hide{display:none}

/* lightbox */
.lb{position:fixed;inset:0;z-index:90;background:rgba(16,13,9,.95);display:none;align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);color:#fff;cursor:pointer;border-radius:999px;display:grid;place-items:center;transition:background .2s}
.lb-close:hover,.lb-nav:hover{background:rgba(255,255,255,.26)}
.lb-close{top:18px;right:18px;width:46px;height:46px}
.lb-close svg,.lb-nav svg{width:22px;height:22px}
.lb-nav{top:50%;transform:translateY(-50%);width:50px;height:50px}
.lb-prev{left:16px}.lb-next{right:16px}

/* ============================================================================
   WHY — dark steel band (03)
   ========================================================================== */
.why{background:var(--ink);color:var(--paper-on-dark);position:relative;overflow:hidden}
.why::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:54px 54px;
  -webkit-mask-image:radial-gradient(110% 80% at 80% 0,#000,transparent 75%);mask-image:radial-gradient(110% 80% at 80% 0,#000,transparent 75%)}
.why .container{position:relative}
.why .eyebrow{color:var(--amber)}
.why .eyebrow::before{background:var(--amber)}
.why h2{color:#fff}
.why .lead{color:var(--steel-on-dark)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,40px);margin-top:clamp(36px,5vw,56px)}
.adv{padding-top:22px;border-top:1px solid rgba(255,255,255,.14)}
.adv-ic{width:38px;height:38px;color:var(--amber);margin-bottom:14px}
.adv-ic svg{width:100%;height:100%;stroke-width:1.5}
.adv h3{color:#fff;font-size:1.18rem;margin-bottom:.4rem}
.adv p{color:var(--steel-on-dark);font-size:.92rem;line-height:1.55;margin:0}
/* ===== proof band (cifre) — standalone light band ===== */
.statsband{background:var(--paper-2);border-block:1px solid var(--line);padding-block:clamp(42px,5.5vw,68px)}
.stats{display:grid;grid-template-columns:repeat(3,1fr)}
.stat{text-align:center;padding-inline:clamp(14px,3vw,40px);position:relative}
.stat:not(:first-child)::before{content:"";position:absolute;left:0;top:8%;height:84%;width:1px;background:var(--line)}
.stat .n{font-family:var(--display);font-weight:800;font-size:clamp(2.1rem,4.8vw,3.4rem);color:var(--timber);line-height:1;letter-spacing:-.03em}
.stat .l{font-family:var(--mono);font-size:.74rem;color:var(--steel);letter-spacing:.05em;margin-top:10px;text-transform:uppercase}
@media (max-width:600px){.stats{grid-template-columns:1fr;gap:26px}.stat:not(:first-child)::before{display:none}}

/* ============================================================================
   PROCESS (04)
   ========================================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,30px);counter-reset:step}
.step{position:relative;padding-top:30px}
.step::before{content:"";position:absolute;top:9px;left:0;right:-30px;height:1.5px;background:var(--line)}
.step:last-child::before{right:0}
.step .dot{position:absolute;top:2px;left:0;width:16px;height:16px;border-radius:50%;background:var(--paper);border:2px solid var(--timber)}
.step .s-n{font-family:var(--mono);font-size:.74rem;color:var(--timber-700);font-weight:600;letter-spacing:.08em}
.step h3{font-size:1.16rem;margin:.5rem 0 .45rem}
.step p{font-size:.92rem;color:var(--steel);margin:0;line-height:1.55}

/* ============================================================================
   FAQ (05)
   ========================================================================== */
.faq-grid{display:grid;grid-template-columns:1fr;gap:0;max-width:860px}
details.qa{border-top:1px solid var(--line);padding:6px 0}
details.qa:last-child{border-bottom:1px solid var(--line)}
.qa summary{display:flex;align-items:center;justify-content:space-between;gap:18px;cursor:pointer;list-style:none;padding:20px 4px;font-family:var(--display);font-weight:600;font-size:clamp(1.04rem,1.5vw,1.22rem);letter-spacing:-.01em}
.qa summary::-webkit-details-marker{display:none}
.qa summary .ic{flex:0 0 auto;width:26px;height:26px;position:relative}
.qa summary .ic::before,.qa summary .ic::after{content:"";position:absolute;inset:50% 4px auto;height:2px;background:var(--timber);top:50%;transition:transform .3s}
.qa summary .ic::after{transform:rotate(90deg)}
.qa[open] summary .ic::after{transform:rotate(0)}
.qa .qa-body{padding:0 4px 22px;color:var(--steel);font-size:.97rem;line-height:1.62;max-width:70ch}
.qa[open] summary{color:var(--timber-700)}

/* ============================================================================
   CONTACT (06)
   ========================================================================== */
.contact{background:var(--paper-2);border-top:1px solid var(--line)}
#contact .eyebrow{display:inline-flex;margin-bottom:clamp(18px,2.6vw,30px)}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,60px);align-items:start}
.contact h2{font-size:clamp(2.1rem,4.6vw,3.4rem)}
.contact-cta{display:flex;align-items:center;flex-wrap:wrap;gap:14px 22px;margin-top:1.5rem}
.contact .big-phone{display:inline-flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,2.7vw,2rem);letter-spacing:-.03em;margin:0}
.contact .big-phone svg{width:1.05em;height:1.05em;color:var(--timber)}
.contact .big-phone:hover{color:var(--timber-700)}
.contact-info{display:grid;gap:14px;margin-top:2rem}
.ci-row{display:flex;gap:13px;align-items:flex-start;font-size:.95rem}
.ci-row svg{width:19px;height:19px;color:var(--timber);flex:0 0 auto;margin-top:3px}
.ci-row b{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--steel-2);font-weight:600;margin-bottom:1px}
/* form */
.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,34px);box-shadow:var(--shadow-sm)}
.form-card h3{font-size:1.3rem;margin-bottom:1.2rem}
.field{margin-bottom:15px}
.field label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:var(--steel);font-weight:600;margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;background:var(--paper);font-family:inherit;font-size:.98rem;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field textarea{resize:vertical;min-height:96px}
.field select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:44px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%236E695E' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.field select:focus{border-color:var(--timber)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--timber);box-shadow:0 0 0 4px rgba(184,106,46,.12)}
.form-note{font-size:.8rem;color:var(--steel-2);margin-top:12px;line-height:1.5}

/* ============================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--ink);color:var(--steel-on-dark);padding-block:clamp(48px,6vw,72px) 30px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand .brand{color:#fff;margin-bottom:14px}
.foot-brand p{max-width:34ch;font-size:.92rem;line-height:1.6;color:var(--steel-on-dark)}
.foot-col h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--steel-2);font-weight:600;margin-bottom:14px}
.foot-col a{display:block;padding:5px 0;font-size:.94rem;color:var(--paper-on-dark);opacity:.86;transition:opacity .2s,color .2s}
.foot-col a:hover{opacity:1;color:var(--amber)}
.foot-bot{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;padding-top:24px;font-size:.8rem;color:var(--steel-2);font-family:var(--mono)}
.foot-bot .demo-tag{border:1px solid rgba(255,255,255,.16);padding:3px 10px;border-radius:7px}

/* ============================================================================
   COOKIE BAR
   ========================================================================== */
.cookie-bar{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:58;display:none;gap:15px;align-items:center;width:max-content;max-width:calc(100vw - 24px);padding:11px 12px 11px 20px;border-radius:999px;background:var(--ink);color:var(--paper-on-dark);box-shadow:var(--shadow-lg);font-size:.84rem}
.cookie-bar.show{display:flex}
.cookie-bar p{margin:0;white-space:nowrap}
.cookie-bar a{color:#fff;text-decoration:underline}
.cookie-bar .btn{padding:.55em 1.1em;font-size:.82rem}
@media (max-width:560px){.cookie-bar{bottom:14px;flex-wrap:wrap;justify-content:center;text-align:center;border-radius:16px}.cookie-bar p{white-space:normal}}

/* ============================================================================
   REVEAL ANIMATIONS
   ========================================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.js .cards>.reveal.in,.js .gallery>.reveal.in,.js .steps>.reveal.in,.js .why-grid>.reveal.in,.js .stats>.reveal.in{transition-delay:calc(var(--i,0)*75ms)}
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.js .hero .anim{opacity:0;animation:heroIn .85s var(--ease) forwards}
.js .hero .anim:nth-child(1){animation-delay:.05s}
.js .hero .anim:nth-child(2){animation-delay:.13s}
.js .hero .anim:nth-child(3){animation-delay:.21s}
.js .hero .anim:nth-child(4){animation-delay:.29s}
.js .hero .anim:nth-child(5){animation-delay:.37s}
.js .hero-media{opacity:0;animation:heroIn 1s var(--ease) .2s forwards}

/* ============================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:980px){
  .nav-links{display:none}
  .nav-cta{margin-left:auto}
  .nav-toggle{display:flex}
  .phone-link span{display:none}
  .hero-grid{grid-template-columns:1fr;gap:54px}
  .hero-media{max-width:560px;margin-inline:auto;width:100%}
  .cards{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step::before{right:-22px}
  .step:nth-child(2n)::before{right:0}
  .contact-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:600px){
  .cards{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step::before{display:none}
  .spec-plate{left:50%;right:auto;transform:translateX(-50%);bottom:-30px;min-width:min(280px,86%)}
  .hero{padding-bottom:64px}
  .hero-cta{flex-wrap:nowrap;gap:10px}
  .hero-cta .btn{flex:1 1 0;padding-inline:.85em;font-size:.94rem;white-space:nowrap}
  .contact-cta{flex-wrap:nowrap;gap:10px}
  .contact-cta .big-phone{font-size:1.2rem;gap:9px}
  .contact-cta .big-phone svg{width:1em;height:1em}
  .contact-cta .btn-wa{flex:0 0 auto;padding-inline:.9em;font-size:.86rem}
}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .js .hero .anim,.js .hero-media{animation:none;opacity:1}
  *{scroll-behavior:auto}
  .shot img,.card-img img{transition:none}
}

/* ============================================================================
   EDIT MODE (CMS) — page-editor.js injected UI
   ========================================================================== */
.editmode .ed-on{outline:1.5px dashed transparent;outline-offset:3px;border-radius:4px;cursor:text;transition:outline-color .15s,background .15s}
.editmode .ed-on:hover{outline-color:var(--timber);background:rgba(184,106,46,.07)}
.editmode .ed-editing{outline:2px solid var(--timber);background:rgba(184,106,46,.07)}
.editmode .ed-on-img{outline:1.5px dashed var(--timber);outline-offset:3px;cursor:grab}
.editmode .ed-grabbing{cursor:grabbing}
.ed-fab{position:fixed;z-index:95;display:none;align-items:center;gap:7px;padding:8px 13px;border-radius:999px;background:var(--timber);color:#fff;border:none;font-weight:600;font-size:.82rem;cursor:pointer;box-shadow:var(--shadow)}
.ed-fab-ic{display:grid;place-items:center}.ed-fab-ic svg{width:15px;height:15px}
.ed-exit{position:fixed;right:18px;bottom:18px;z-index:95;display:none;align-items:center;gap:9px;padding:13px 19px;border-radius:999px;background:var(--ink);color:#fff;border:none;font-weight:600;cursor:pointer;box-shadow:var(--shadow-lg)}
.ed-exit svg{width:18px;height:18px;color:var(--ok)}
.ed-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);z-index:96;padding:11px 20px;border-radius:999px;background:var(--ink);color:#fff;font-size:.88rem;font-weight:500;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none}
.ed-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.ed-toast.warn{background:var(--warn)}
.ed-add{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;border:1.5px dashed var(--timber);background:rgba(184,106,46,.08);color:var(--timber-700);font-weight:600;font-size:.86rem;cursor:pointer}
.ed-add svg{width:16px;height:16px}
.gallery .ed-add{display:grid;place-content:center;border-radius:var(--r);min-height:100%}
.ed-del{position:absolute;top:-7px;right:-7px;z-index:6;width:20px;height:20px;padding:0;border-radius:50%;background:var(--warn);color:#fff;border:2px solid #fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 2px 7px -1px rgba(25,24,20,.4);transition:transform .15s}
.ed-del svg{width:11px;height:11px}
.ed-del:hover{transform:scale(1.12)}
.gallery .ed-del{top:10px;right:10px;width:30px;height:30px}
.gallery .ed-del svg{width:15px;height:15px}
.ed-drop{outline:2.5px dashed var(--timber)!important;outline-offset:3px;background:rgba(184,106,46,.1)}
.ed-item{position:relative}
.editmode .card-tags{gap:10px}
/* mobil: imaginile editabile se ating pentru a fi schimbate */
.editmode .ed-tap{cursor:pointer}
.editmode .ed-on-img.ed-tap{outline-width:2px}
/* butonul „Gata, ies din editare" — vizibil garantat, inclusiv sub notch/home-bar */
@supports (padding: max(0px)){ .ed-exit{bottom:max(18px,env(safe-area-inset-bottom));right:max(16px,env(safe-area-inset-right))} }
@media (max-width:600px){
  .ed-exit{right:14px;padding:12px 17px;font-size:.92rem}
  .ed-toast{bottom:max(84px,calc(env(safe-area-inset-bottom) + 78px))}
}
/* footer: bloc NAP + linkuri legale (Confidențialitate/Termeni/ANPC/SAL) */
.foot-nap{font-style:normal;font-size:.9rem;line-height:1.75;color:var(--paper-on-dark);opacity:.85;margin-bottom:12px}
.foot-legal{display:inline-flex;flex-wrap:wrap;gap:6px 16px}
.foot-legal a{color:var(--steel-2);opacity:.9;transition:color .2s,opacity .2s}
.foot-legal a:hover{color:var(--amber);opacity:1}
/* mobil îngust: brandul „Case Trainice" pe un rând (CTA-ul din header rămâne accesibil în meniu + hero) */
@media (max-width:560px){
  .site-header .nav-cta .btn-primary{display:none}
  .brand-word{white-space:nowrap}
  .site-header .brand{font-size:1.22rem}
}
