/* Atelier Pilates – stil design v4 pentru pagina Elementor.
   Stil „legat" pe clase CSS pe care le pui pe secțiuni/widget-uri în Elementor.
   Structura = Elementor (editabilă); aspectul fin = aici. */

:root{
	--green-900:#334234; --green-800:#435540; --green-700:#596b55; --green-600:#6f8069;
	--green-500:#86947c; --green-100:#f3f7ea; --cream:#fffdf6; --cream-2:#faf8ef; --sand:#e6e2d3;
	--line:rgba(67,85,64,.18); --apv4-text:#11130f; --muted:#6f766a; --accent:#c47d61;
	--shadow:0 24px 70px rgba(31,41,30,.12); --shadow-soft:0 14px 40px rgba(31,41,30,.08);
	--serif:"Cormorant Garamond",Georgia,serif; --sans:"Inter",Arial,sans-serif;
}

/* fundal cremă pe pagina v4 */
body.ap-v4 .elementor{ background:transparent; }
body.ap-v4{
	font-family:var(--sans); color:var(--apv4-text);
	background:
		radial-gradient(circle at 15% 16%, rgba(134,148,124,.12), transparent 34%),
		radial-gradient(circle at 88% 50%, rgba(196,125,97,.06), transparent 30%),
		var(--cream);
}

/* helperi de tip „kicker / titlu / copy" (puși ca CSS class pe widget-uri) */
.ap-kicker .elementor-heading-title, .ap-kicker{ display:inline-flex; align-items:center; gap:12px; color:var(--green-800); font-family:var(--sans); font-size:12px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; }
body .ap-kicker .elementor-heading-title{ color:var(--green-800); }
.ap-kicker .elementor-heading-title::after{ content:""; width:42px; height:1px; background:currentColor; opacity:.35; display:inline-block; }
.ap-h2 .elementor-heading-title, .ap-h2{ font-family:var(--serif); font-size:clamp(43px,5.2vw,70px); line-height:.95; letter-spacing:-.045em; font-weight:700; margin:0; }
body .ap-h2 .elementor-heading-title, .ap-about-grid .ap-h2{ color:var(--green-800); }
.ap-copy, .ap-copy p{ color:#1c221b; font-size:16px; }
/* kicker inline (în widget-uri custom) */
.ap-kick{ display:inline-flex; align-items:center; gap:12px; margin-bottom:14px; color:var(--green-800); font-family:var(--sans); font-size:12px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; }
.ap-kick::after{ content:""; width:42px; height:1px; background:currentColor; opacity:.35; }

/* butoane v4 */
.ap-btn{ display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:46px; padding:0 24px; border:1px solid transparent; border-radius:999px; background:var(--green-700); color:#fff; font-family:var(--sans); font-weight:800; font-size:14px; box-shadow:0 12px 28px rgba(67,85,64,.20); transition:transform .2s,box-shadow .2s,background .2s; cursor:pointer; white-space:nowrap; text-decoration:none; }
.ap-btn:hover{ transform:translateY(-2px); background:var(--green-800); color:#fff !important; box-shadow:0 18px 36px rgba(67,85,64,.26); }
.ap-btn.ap-secondary{ background:transparent; color:var(--green-800) !important; border-color:rgba(67,85,64,.35); box-shadow:none; }
.ap-btn.ap-secondary:hover{ background:rgba(89,107,85,.08); color:var(--green-800) !important; }

/* =================== HERO (widget ap_hero) =================== */
.ap-hero-section .elementor-container,
.ap-hero-section .elementor-widget-wrap{ padding:0 !important; }
.ap-hero-shell{ min-height:650px; position:relative; overflow:hidden; max-width:100%; border-radius:0 0 64px 64px; background:#1f2a20; box-shadow:inset 0 -120px 120px rgba(0,0,0,.22); }
.ap-hero-bg{ position:absolute; inset:0; z-index:0; }
.ap-hero-bg-slide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1.4s ease; }
.ap-hero-bg-slide.is-active{ opacity:1; }
.ap-hero-tint{ position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(90deg, rgba(18,21,16,.76) 0%, rgba(18,21,16,.48) 39%, rgba(18,21,16,.26) 100%); }
.ap-hero-shell::before{ content:""; position:absolute; inset:0 auto 0 0; width:min(54vw,720px); z-index:2; background:radial-gradient(circle at 35% 24%, rgba(255,255,255,.12), transparent 24%), linear-gradient(150deg, rgba(67,85,64,.96), rgba(44,58,43,.96)); clip-path:ellipse(74% 78% at 25% 50%); opacity:.95; }
.ap-hero-content{ position:relative; z-index:3; width:min(540px,88%); max-width:100%; padding:clamp(78px,9vw,138px) 0 90px clamp(24px,6vw,72px); color:#fff; }
.ap-eyebrow{ display:inline-flex; align-items:center; gap:14px; margin-bottom:18px; color:rgba(255,255,255,.86); font-size:13px; font-weight:800; letter-spacing:.23em; text-transform:uppercase; }
.ap-eyebrow::after{ content:""; width:50px; height:1px; background:currentColor; opacity:.42; }
.ap-hero-h1{ margin:0; max-width:520px; font-family:var(--serif); font-size:clamp(70px,8.2vw,126px); font-weight:600; line-height:.82; letter-spacing:-.055em; }
.ap-hero-p{ width:min(410px,100%); margin:28px 0; color:rgba(255,255,255,.92); font-size:17px; font-weight:600; }
.ap-hero-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:16px; }
.ap-play-link{ display:inline-flex; align-items:center; gap:10px; color:rgba(255,255,255,.92); font-size:14px; font-weight:800; }
.ap-play-link i{ width:40px; height:40px; border:1px solid rgba(255,255,255,.45); border-radius:50%; display:grid; place-items:center; font-style:normal; background:rgba(255,255,255,.08); }
.ap-hero-meta{ position:absolute; z-index:4; left:clamp(24px,6vw,72px); bottom:52px; display:flex; align-items:center; gap:16px; }
.ap-hero-meta .ap-dot{ width:9px; height:9px; border-radius:50%; border:0; padding:0; background:rgba(255,255,255,.45); cursor:pointer; }
.ap-hero-meta .ap-dot.is-active{ background:#fff; transform:scale(1.25); }
.ap-glass-card{ position:absolute; right:clamp(24px,7vw,88px); bottom:44px; z-index:4; width:min(610px,52vw); display:grid; grid-template-columns:repeat(3,1fr); overflow:hidden; border:1px solid rgba(255,255,255,.36); border-radius:28px; background:rgba(255,255,255,.14); backdrop-filter:blur(18px); box-shadow:0 20px 55px rgba(0,0,0,.22); }
.ap-glass-item{ min-height:128px; padding:24px 22px; color:rgba(255,255,255,.9); display:grid; justify-items:center; text-align:center; align-content:center; gap:10px; font-size:13px; font-weight:700; }
.ap-glass-item + .ap-glass-item{ border-left:1px solid rgba(255,255,255,.24); }
.ap-glass-item svg{ width:31px; height:31px; color:#dce8d7; }

/* =================== ABOUT (widget ap_about) =================== */
.ap-about-section{ background:radial-gradient(circle at 8% 68%, rgba(134,148,124,.14), transparent 18%), linear-gradient(180deg,#fffdf6 0%,#fbfbf1 100%); }
.ap-about-grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(42px,7vw,96px); align-items:start; }
.ap-about-media{ display:grid; grid-template-columns:1fr 250px; gap:28px; align-items:end; }
.ap-about-copy{ max-width:610px; color:#1c221b; font-size:16px; }
.ap-about-copy p{ margin:0 0 16px; }
.ap-about-photo{ position:relative; min-height:340px; border-radius:34px 34px 92px 34px; overflow:hidden; box-shadow:var(--shadow-soft); background-size:cover; background-position:center; }
.ap-stamp{ width:148px; height:auto; margin:0 auto 6px; display:block; }
.ap-benefits{ grid-column:1 / -1; display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:26px; padding:14px; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.62); box-shadow:var(--shadow-soft); }
.ap-benefit{ display:flex; align-items:center; gap:13px; min-height:76px; padding:0 18px; border-right:1px solid var(--line); font-size:14px; font-weight:700; color:var(--green-800); }
.ap-benefit:last-child{ border-right:0; }
.ap-benefit i{ width:46px; height:46px; min-width:46px; display:grid; place-items:center; border-radius:50%; background:#fff; box-shadow:0 9px 24px rgba(31,41,30,.08); font-style:normal; }

/* =================== PRICING (intro col) =================== */
.ap-pricing-section{ background:linear-gradient(180deg,#fff 0%,#fffdf6 70%,#f5f8ed 100%); }
.ap-pricing-intro .elementor-widget{ margin-bottom:0; }
.ap-pricing-intro p{ margin:18px 0 24px; color:#323a30; font-size:15px; }

/* =================== SCHEDULE (panel + orar) =================== */
.ap-schedule-section{ background:var(--green-100); }
.ap-schedule-section > .elementor-container{ border-radius:32px; overflow:hidden; box-shadow:var(--shadow-soft); background:rgba(255,255,255,.75); border:1px solid rgba(67,85,64,.16); }
.ap-schedule-intro{ background:radial-gradient(circle at 20% 0%, rgba(255,255,255,.14), transparent 32%), linear-gradient(140deg, var(--green-700), var(--green-900)); }
.ap-schedule-intro .elementor-widget-wrap{ padding:44px 38px !important; }
.ap-schedule-intro .ap-h2 .elementor-heading-title{ color:#f4f7ea; }
.ap-schedule-intro .ap-kicker .elementor-heading-title{ color:rgba(255,255,255,.82); }
.ap-schedule-intro p, .ap-schedule-intro .elementor-widget-text-editor{ color:rgba(255,255,255,.8); font-size:15px; }
.ap-schedule-cal .elementor-widget-wrap{ padding:0 !important; }
.ap-schedule-cal{ min-width:0; }

/* orar live restilizat ca .calendar din design */
.ap-schedule-cal .ap-orar{ display:grid !important; grid-auto-flow:column !important; grid-auto-columns:minmax(165px,1fr) !important; grid-template-columns:none !important; gap:0 !important; overflow-x:auto; padding:36px 24px 30px; background:transparent; font-family:var(--sans); }
.ap-schedule-cal .ap-zi{ background:transparent; border-radius:0; padding:0 16px; min-height:420px; border-left:1px solid rgba(67,85,64,.12); }
.ap-schedule-cal .ap-orar .ap-zi:first-child{ border-left:0; }
.ap-schedule-cal .ap-zi-cap{ display:block; padding:6px 0 14px; margin-bottom:0; border-bottom:1px solid rgba(67,85,64,.12); }
.ap-schedule-cal .ap-zi-nume{ font-family:var(--sans); font-weight:900; font-size:14px; color:var(--apv4-text); }
.ap-schedule-cal .ap-zi-data{ display:block; margin-top:2px; color:var(--muted); font-size:12px; font-weight:500; opacity:1; }
.ap-schedule-cal .ap-gol{ margin-top:16px; color:rgba(67,85,64,.55); font-size:13px; font-weight:600; }
.ap-schedule-cal .ap-slot{ margin:14px 0 0; padding:16px 16px 14px; border-radius:16px; background:#fff; box-shadow:0 12px 26px rgba(31,41,30,.08); border-left:4px solid var(--ap-color,#596b55); }
.ap-schedule-cal .ap-ora{ font-weight:900; font-size:13px; }
.ap-schedule-cal .ap-lectie{ margin:4px 0 8px; font-weight:800; font-size:13px; }
.ap-schedule-cal .ap-instructor{ display:inline-flex; padding:3px 9px; border-radius:999px; background:var(--ap-color,#596b55); color:#fff; font-size:10px; font-weight:900; margin-top:0; }
.ap-schedule-cal .ap-libere{ margin:9px 0 10px; color:var(--muted); font-size:12px; }
.ap-schedule-cal .ap-btn-rezerva{ width:100%; min-height:34px; border:0; border-radius:999px; background:var(--green-700); color:#fff; font-weight:900; cursor:pointer; margin-top:0; font-family:var(--sans); }
.ap-schedule-cal .ap-btn-rezerva:hover{ background:var(--green-800); }
.ap-modal-box{ background:var(--cream); }
.ap-modal-box h3{ font-family:var(--serif); color:var(--green-800); font-size:28px; }

/* =================== CONTACT =================== */
.ap-contact-section{ background:#fff; }
.ap-contact-info{ background:var(--green-800); border-radius:32px; position:relative; overflow:hidden; }
.ap-contact-info .elementor-widget-wrap{ padding:36px !important; }
.ap-contact-info::after{ content:""; position:absolute; right:-80px; bottom:-105px; width:260px; height:260px; border:1px solid rgba(255,255,255,.16); border-radius:50%; }
.ap-contact-info .ap-h2 .elementor-heading-title{ color:#fff; }
.ap-contact-info .ap-kicker .elementor-heading-title{ color:rgba(255,255,255,.78); }
.ap-contact-info .elementor-widget-text-editor{ color:rgba(255,255,255,.85); position:relative; z-index:1; }
.ap-contact-info .elementor-widget-text-editor b{ color:#fff; }
.ap-map-wrap{ min-height:470px; border-radius:32px; overflow:hidden; position:relative; box-shadow:var(--shadow-soft); border:1px solid rgba(67,85,64,.12); background:#eef1ea; }
.ap-map-wrap iframe{ width:100%; height:100%; min-height:470px; border:0; display:block; filter:saturate(.8) contrast(.92) brightness(1.04); }
.ap-map-wrap .elementor-widget-wrap{ padding:0 !important; }
.ap-map-wrap .elementor-widget, .ap-map-wrap .elementor-widget-container{ height:100%; }
.ap-map-popup{ position:absolute; left:28px; top:28px; z-index:2; width:min(310px,calc(100% - 56px)); padding:22px; border-radius:20px; background:rgba(255,255,255,.92); backdrop-filter:blur(12px); box-shadow:var(--shadow-soft); }
.ap-map-popup b{ display:block; margin-bottom:3px; }
.ap-map-popup a{ display:inline-flex; margin-top:13px; color:var(--green-800); font-weight:900; font-size:13px; }

/* butoane native Elementor stilizate ca v4 (clasă pe widgetul Button) */
.ap-btnw .elementor-button{ display:inline-flex; align-items:center; gap:10px; min-height:46px; padding:0 24px; border-radius:999px; background:var(--green-700); color:#fff; font-family:var(--sans); font-weight:800; font-size:14px; box-shadow:0 12px 28px rgba(67,85,64,.20); }
.ap-btnw .elementor-button:hover{ background:var(--green-800); }
.ap-btnw.ap-secondary-w .elementor-button{ background:transparent; color:var(--green-800); border:1px solid rgba(67,85,64,.35); box-shadow:none; }
.ap-schedule-intro .ap-btnw.ap-secondary-w .elementor-button{ color:#fff; border-color:rgba(255,255,255,.42); }

/* =================== HEADER / FOOTER (HFE) =================== */
.ap-v4-brand{ display:inline-flex; align-items:center; gap:12px; text-decoration:none; }
.ap-v4-brand img{ width:40px; height:auto; }
.ap-v4-brand span{ font-family:var(--serif); font-weight:700; color:var(--green-800); letter-spacing:-.03em; font-size:30px; line-height:1; }
.ehf-header .hfe-nav-menu a.hfe-menu-item{ font-family:var(--sans); font-weight:700; font-size:14px; color:#20251f; }
.ehf-header #masthead .elementor-section{ background:transparent; }
.ap-v4-footer{ background:var(--green-900); }
.ap-v4-footer img{ width:150px; height:auto; }
.ap-v4-footer .elementor-widget-text-editor{ color:rgba(255,255,255,.78); font-size:13px; }
.ap-v4-footer a{ color:rgba(255,255,255,.85); }

/* =================== RESPONSIVE =================== */
@media (max-width:1100px){
	.ap-about-grid, .ap-about-media{ grid-template-columns:1fr; }
	.ap-stamp{ display:none; }
}
@media (max-width:1024px){
	.ap-hero-shell{ min-height:auto; display:flex; flex-direction:column; padding-bottom:18px; }
	.ap-hero-content{ width:min(560px,100%); padding:72px 28px 24px; }
	.ap-hero-meta{ position:static; margin:0 28px 14px; }
	.ap-glass-card{ position:static; width:auto; max-width:calc(100% - 36px); margin:0 18px; }
}
@media (max-width:820px){
	.ap-hero-shell{ border-radius:0 0 38px 38px; background-position:60% center; }
	.ap-hero-h1{ font-size:clamp(52px,14vw,82px); max-width:100%; }
	.ap-hero-p{ font-size:15px; max-width:340px; }
	.ap-glass-card{ grid-template-columns:1fr; margin:0 18px; max-width:calc(100% - 36px); border-radius:24px; }
	.ap-glass-item{ min-height:auto; grid-template-columns:44px 1fr; justify-items:start; text-align:left; padding:16px 20px; }
	.ap-glass-item + .ap-glass-item{ border-left:0; border-top:1px solid rgba(255,255,255,.24); }
	.ap-benefits{ grid-template-columns:1fr; border-radius:28px; }
	.ap-benefit{ border-right:0; border-bottom:1px solid var(--line); }
	.ap-benefit:last-child{ border-bottom:0; }
	.ap-schedule-intro .elementor-widget-wrap{ padding:34px 26px !important; }
}
@media (max-width:520px){
	.ap-hero-content{ padding:64px 20px 24px; }
	.ap-hero-actions{ align-items:stretch; }
	.ap-map-wrap iframe{ min-height:330px; }
}
@media (prefers-reduced-motion:reduce){ .ap-hero-bg-slide{ transition:none; } }

/* Navigare orar în secțiunea Programare (v4) */
.ap-schedule-cal .ap-orar-nav{ padding:28px 26px 0; margin:0; }
.ap-schedule-cal .ap-orar{ padding-top:14px; }
