/* ================= psi.css — layout alternant stânga/dreapta, corect pe mobil ================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Lora:wght@600;700&display=swap');

/* Reset + fără scroll orizontal */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;width:100%;max-width:100%;overflow-x:hidden}
img,video,canvas,iframe{display:block;max-width:100%;height:auto}

/* Paletă + tipografie */
:root{
  --bg1:#e8fbef; --bg2:#c9f2da; --bg3:#b1eac9;
  --surface:#ffffff;
  --text:#182920; --muted:#4a6b59;
  --accent:#1e9b5f; --accent-ink:#ffffff;
  --line:#d3eadb; --ring:#37c786;
  --shadow-md:0 12px 30px rgba(24,41,32,.12);

  --font-sans:"Inter",system-ui,sans-serif;
  --font-serif:"Lora",serif;

  --fs-sm:13px; --fs-md:15px; --fs-lg:clamp(17px,2vw,19px);
  --fs-xl:clamp(22px,3vw,28px); --fs-2xl:clamp(30px,4.5vw,44px);
}

/* Fundal 3D sub tot */
body{
  font:var(--fs-md)/1.65 var(--font-sans);
  color:var(--text);
  background:linear-gradient(to bottom,var(--bg1),var(--bg2) 45%,var(--bg3) 100%);
  -webkit-font-smoothing:antialiased;
}
#bg3d{position:fixed;inset:0;width:100vw;height:100vh;z-index:-2;pointer-events:none}

/* Banner orientativ */
.notice{position:sticky;top:0;z-index:4;background:rgba(232,251,239,.9);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.notice p{margin:0;padding:8px 14px;font-size:12px;color:var(--muted)}

/* Header */
.site-header{
  position:sticky;top:38px;z-index:3;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:8px 14px;background:linear-gradient(to top,var(--bg1),var(--bg2) 45%,var(--bg3) 100%);
  border-bottom:1px solid var(--line);backdrop-filter:blur(6px)
}
.brand-vertical{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:56px}
#logo3d{width:56px;height:56px;background:transparent}
.brand-name{font-weight:800;letter-spacing:.14em;font-size:11px;text-transform:uppercase;color:var(--text)}

.nav{display:flex;gap:8px;padding: 20px;border-bottom: 1px solid black; background:linear-gradient(to top,var(--bg1),var(--bg2) 45%,var(--bg3) 100%); flex-wrap:wrap}
.nav a{
  text-decoration:none;color:var(--text);font-weight:600;font-size:14px;
  padding:8px 12px;border-radius:9px;background:rgba(255,255,255,.75);border-bottom: 1px solid black;
}
.nav a:hover{background:#fff}
.menu-btn{display:none}
.cta-header{text-decoration:none;font-weight:700;background:var(--accent);color:#fff;padding:8px 12px;border-radius:10px;box-shadow:var(--shadow-md);white-space:nowrap}

/* Meniu mobil */
.mobile-menu[aria-hidden="true"]{display:none}
.mobile-menu[aria-hidden="false"]{
  position:fixed;inset:0;z-index:10;background:rgba(0,0,0,.28);
  display:grid;place-items:center
}
.mobile-sheet{width:min(92vw,380px);background:#fff;border-radius:14px;padding:16px;box-shadow:var(--shadow-md);display:grid;gap:8px}
.mobile-sheet a{text-decoration:none;color:var(--text);padding:10px;border-radius:10px;border:1px solid var(--line)}
.mobile-close{justify-self:end;border:0;background:#eef6;width:34px;height:34px;border-radius:10px;cursor:pointer}
.cta-mobile{background:var(--accent);color:#fff;text-align:center}

/* HERO */
.hero{padding:22px 14px 16px}
.hero-inner{padding: 20px; background:linear-gradient(to top,var(--bg1),var(--bg2) 45%,var(--bg3) 100%);
  max-width:1100px;margin:0 auto;border: 1px solid black;border-radius: 10px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:center
}
.hero h1{font-family:var(--font-serif);font-size:clamp(34px,5.6vw,58px);line-height:1.1;margin:0 0 8px;text-align:center;color:#163b2a}
.hero .sub{margin:0 0 10px;text-align:center;color:#254c3a}
.cta-row{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 6px;justify-content:center}
.btn{ text-decoration:none;padding:10px 14px;border-radius:10px;font-weight:700;border:1px solid var(--line);background:linear-gradient(to bottom,var(--bg1),var(--bg2) 45%,var(--bg3) 100%); }
.btn-primary{background:var(--accent);color:#fff}
.btn-outline{background:#fff;border: 1px solid black; color:#0f3b28}
.trust{margin:9px 20px;text-align:center;align-items: center; list-style:none;display:flex;gap:10px;flex-wrap:wrap;border:1px solid black;padding:10px;background:linear-gradient(to bottom,var(--bg1),var(--bg2) 45%,var(--bg3) 100%); color:#2a5a46}
.hero-col.visual img{width:100%;margin-right: 20px; border-radius:16px;box-shadow:var(--shadow-md)}

/* ========= Secțiuni About: alternanță desktop, imagine deasupra pe mobil ========= */
.about-section{border-left: 1px solid black; padding:16px 14px}
.about-content{
  width:100%;
  max-width:1100px;margin-inline:auto;
  display:grid;gap:24px;align-items:center;
 background:linear-gradient(to bottom,var(--bg1),var(--bg2) 45%,var(--bg3) 100%);;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-md);
  padding:18px;overflow:hidden
}

/* Desktop: două coloane și alternanță prin data-side */
@media (min-width:901px){
  .about-section[data-side="left"]  .about-content{grid-template-columns:380px 1fr}
  .about-section[data-side="right"] .about-content{grid-template-columns:1fr 380px}
  .about-section[data-side="left"]  .about-photo{order:1}
  .about-section[data-side="left"]  .about-text {order:2}
  .about-section[data-side="right"] .about-photo{order:2}
  .about-section[data-side="right"] .about-text {order:1}
}

/* Mobil/tabletă: o coloană. Imaginea deasupra textului pentru toate. */
@media (max-width:900px){
  .about-content{grid-template-columns:1fr;text-align:center}
  .about-photo{order:1}
  .about-text {order:2}
}

.about-photo{
  width:100%;max-width:360px;margin-inline:auto;
  border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.1)
}
.about-text h2{font-size:var(--fs-2xl);margin:0 0 6px;font-family:var(--font-serif);color:#133d2a}
.about-text h3{font-size:var(--fs-lg);margin:0 0 8px;color:var(--accent)}
.about-text p{margin:0 0 8px}
.bullets{margin:0 0 8px 18px}

/* Dimensiuni foto per secțiune */
#despre   .about-photo{max-width:240px}
#servicii .about-photo{max-width:320px}

/* Tarife */
.prices{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}
.prices.slim{grid-template-columns:repeat(3,minmax(0,1fr))}
.price{
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:10px 12px;display:flex;justify-content:space-between;gap:10px;min-width:0
}
.price span{color:var(--accent);font-weight:800}
.policies{color:#2a5a46}

/* Secțiuni largi: Portofoliu, Testimoniale, Contact */
.section.wide{padding:22px 14px}
.section.wide > *{max-width:1100px;margin-inline:auto}
.section.wide h2{font-size:var(--fs-2xl);margin:0 0 8px;color:#123b29}

/* Galerie Cabinet */
.gallery{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}
.gallery figure{margin:0;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md)}
.gallery figcaption{padding:8px 10px;color:#2b5a47}

/* Testimoniale */
.cards.testi{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}
.testi-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;display:grid;gap:6px;box-shadow:var(--shadow-md)}
.avatar{width:40px;height:40px;border-radius:50%}

/* Contact */
.section-contact .contact-wrap{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.1fr;gap:16px
}
.contact-list{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.contact-list a{color:#0f3b28;font-weight:700;text-decoration:none}
.map iframe{width:100%;min-height:300px;border:0;border-radius:10px}

/* Citește mai mult */
.read-more,.more-btn{
  appearance:none;border:1px solid var(--line);background:linear-gradient(to bottom,var(--bg1),var(--bg2) 45%,var(--bg3) 100%);;color:#123b29;
  padding:8px 12px;border-radius:10px;font-weight:700;cursor:pointer
}
.read-more:hover{background:#f7fffb}

/* Modal */
.modal[aria-hidden="true"]{display:none}
.modal[aria-hidden="false"]{
  position:fixed;inset:0;z-index:20;display:grid;place-items:center;background:rgba(0,0,0,.35);padding:14px
}
.modal-dialog{width:min(92vw,680px);max-height:78vh;overflow:auto;background:#fff;border-radius:14px;box-shadow:var(--shadow-md);padding:16px}
.modal-close{border:0;background:#eef6;width:32px;height:32px;border-radius:10px;cursor:pointer;float:right;margin:-4px -4px 6px 6px}

/* Sus */
.to-top{position:fixed;right:14px;bottom:14px;z-index:4;width:42px;height:42px;border-radius:10px;background:var(--accent);color:#fff;border:0;cursor:pointer;box-shadow:var(--shadow-md)}

/* Footer */
.site-footer{text-align:center;color:var(--muted);padding:18px 14px;border-top:1px solid var(--line);background:rgba(232,251,239,.9)}
.footer-social{display:flex;gap:10px;justify-content:center;align-items:center;margin-bottom:6px}
.footer-social img{width:22px;height:22px}
/* ===== Secțiuni About pe jumătate de pagină, alternanță stânga/dreapta ===== */
.about-section{
  padding:16px 14px;
  display:grid;
  grid-template-columns:1fr 1fr; /* două coloane egale = 50% / 50% */
  align-items:stretch;
}

/* containerul NU mai este centrat */
.about-content{
  width:100%;
  margin:0;                 /* elimină centrare */
  display:grid;gap:24px;align-items:center;
  background:rgba(255,255,255,.92);border:1px solid var(--line);
  border-radius:18px;box-shadow:var(--shadow-md);padding:18px;overflow:hidden;
}

/* poziționare pe jumătate: stânga sau dreapta */
.about-section[data-side="left"]  .about-content{grid-column:1}
.about-section[data-side="right"] .about-content{grid-column:2}

/* interiorul rămâne cu 2 coloane pe desktop, imagine/text inverse după side */
@media (min-width:901px){
  .about-section[data-side="left"]  .about-content{grid-template-columns:380px 1fr}
  .about-section[data-side="right"] .about-content{grid-template-columns:1fr 380px}
  .about-section[data-side="left"]  .about-photo{order:1}
  .about-section[data-side="left"]  .about-text {order:2}
  .about-section[data-side="right"] .about-photo{order:2}
  .about-section[data-side="right"] .about-text {order:1}
}
/* ===== Secțiuni full-width: Servicii, Tarife, Contact ===== */
#servicii,
#tarife,
#contact {
  grid-template-columns: 1fr !important; /* o singură coloană */
  display: block !important;             /* ocupă toată pagina */
}

#servicii .about-content,
#tarife .about-content {
  max-width: 1100px;
  margin-inline: auto;
  grid-template-columns: 1fr; /* imagine + text pe verticală implicit */
  text-align: center;
}

#contact .contact-wrap {
  grid-template-columns: 1fr 1fr; /* două coloane pe desktop */
}
@media (max-width:900px) {
  #contact .contact-wrap {
    grid-template-columns: 1fr;  /* stacked pe mobil */
  }
}
/* mobil/tabletă: 100% lățime, imaginea deasupra textului */
@media (max-width:900px){
  .about-section{grid-template-columns:1fr}
  .about-content{grid-column:1;grid-template-columns:1fr;text-align:center}
  .about-photo{order:1}
  .about-text {order:2}
}

/* dimensiuni foto */
.about-photo{
  width:100%;max-width:360px;margin-inline:auto;
  border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.1)
}
#despre   .about-photo{max-width:240px}
#servicii .about-photo{max-width:320px}

/* ===== Figură geometrică asociată secțiunii (dacă există un element .geo) ===== */
.about-section .geo{justify-self:start}
.about-section[data-side="right"] .geo{justify-self:end}
/* ===== Breakpoints ===== */
@media (max-width:1100px){
  .hero-inner{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:900px){
  #logo3d{width:44px;height:44px}
  .menu-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;padding:8px 10px;border-radius:10px}
  .nav,.cta-header{display:none}

  .about-photo{max-width:240px}
  #despre   .about-photo{max-width:200px}
  #servicii .about-photo{max-width:220px}

  .prices,.prices.slim{grid-template-columns:1fr}
  .cards.testi{grid-template-columns:1fr}
  .section-contact .contact-wrap{grid-template-columns:1fr}
}

@media (max-width:600px){
  #logo3d{width:36px;height:36px}
  .hero h1{font-size:clamp(28px,8vw,36px)}
  .hero .sub{font-size:var(--fs-sm)}
  .btn{padding:9px 12px;font-size:14px}

  .about-photo{max-width:180px}
  #despre   .about-photo{max-width:160px}
  #servicii .about-photo{max-width:180px}

  .gallery{grid-template-columns:1fr}
  .avatar{width:36px;height:36px}
  .modal-dialog{width:min(94vw,560px)}
}

/* Siguranță: containerele nu depășesc lățimea */
.hero,.about-section,.section,.site-header,.notice,.site-footer{width:100%}
.hero-inner,.about-content,.section > *,.section.wide > *{max-width:1100px;margin-inline:auto}
:where(.about-content,.price,.hero-inner,.contact-wrap,.gallery,.cards){min-width:0}