:root {
  --bg:#FAFAF8; --card:#fff; --text:#1A1714; --muted:#79746E;
  --accent:#C09468; --accent-dark:#8C6840; --border:#E9E4DC;
  --radius:18px; --nav-h:70px;
  --shadow:0 2px 16px rgba(26,23,20,.06);
  --shadow-md:0 8px 32px rgba(26,23,20,.09);
  --shadow-lg:0 24px 64px rgba(26,23,20,.14);
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:"Manrope",sans-serif; background:var(--bg); color:var(--text); line-height:1.65; overflow-x:hidden; display:flex; flex-direction:column; min-height:100dvh; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
h1,h2,h3,h4 { font-family:"Playfair Display",serif; line-height:1.15; letter-spacing:-.02em; }
h1 { font-size:clamp(2.2rem,5vw,3.8rem); }
h2 { font-size:clamp(1.7rem,3.5vw,2.6rem); }
h3 { font-size:clamp(1.1rem,2vw,1.4rem); }
.eyebrow { display:inline-block; font-size:.68rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--accent); }
.wrap { width:min(1200px,92vw); margin:0 auto; }
.site-bg { display:none; }
/* NAV */
.main-header { position:sticky; top:0; z-index:50; height:var(--nav-h); background:rgba(250,250,248,.9); border-bottom:1px solid var(--border); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:100%; }
.logo { display:flex; flex-direction:column; gap:.05rem; }
.logo-name { font-family:"Playfair Display",serif; font-size:1.25rem; font-weight:600; color:var(--text); }
.logo-sub { font-size:.6rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); }
.logo-img { height:40px; max-width:180px; object-fit:contain; display:block; }
.main-nav { display:flex; align-items:center; gap:.1rem; list-style:none; }
.main-nav a { display:block; padding:.45rem .8rem; border-radius:10px; font-size:.875rem; font-weight:500; color:var(--muted); transition:color .2s,background .2s; }
.main-nav a:hover { color:var(--text); background:rgba(26,23,20,.06); }
.nav-cta { padding:.5rem 1.2rem !important; background:var(--text) !important; color:#fff !important; border-radius:99px !important; font-weight:600 !important; }
.nav-cta:hover { background:var(--accent-dark) !important; }
.nav-burger { display:none; flex-direction:column; gap:5px; padding:.5rem; background:none; border:none; cursor:pointer; }
.nav-burger span { display:block; width:22px; height:1.5px; background:var(--text); border-radius:2px; transition:all .25s ease; }
.nav-burger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity:0; }
.nav-burger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.mobile-nav { display:none; position:fixed; inset:var(--nav-h) 0 0 0; background:rgba(250,250,248,.97); backdrop-filter:blur(16px); z-index:49; padding:2rem; overflow-y:auto; }
.mobile-nav.open { display:block; }
.mobile-nav ul { list-style:none; display:grid; gap:.4rem; }
.mobile-nav a { display:block; font-size:1.05rem; font-weight:500; padding:.8rem 1rem; border-radius:12px; transition:background .18s; }
.mobile-nav a:hover { background:rgba(26,23,20,.05); }
/* LAYOUT */
main { flex:1; }
.page-wrap { width:min(1200px,92vw); margin:0 auto; padding:3.5rem 0 6rem; }
.section { padding:5rem 0; }
.section-sm { padding:3rem 0; }
.section-head { margin-bottom:3rem; }
.section-head p { margin-top:.75rem; color:var(--muted); max-width:50ch; font-size:1rem; line-height:1.75; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:.5rem; padding:.7rem 1.5rem; border-radius:99px; font-family:"Manrope",sans-serif; font-size:.875rem; font-weight:600; border:1.5px solid transparent; cursor:pointer; text-decoration:none; transition:all .2s ease; white-space:nowrap; line-height:1; }
.btn-dark { background:var(--text); color:#fff; border-color:var(--text); }
.btn-dark:hover { background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-1px); }
.btn-ghost { background:transparent; color:var(--text); border-color:var(--border); }
.btn-ghost:hover { border-color:var(--text); }
.btn-accent { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-accent:hover { background:var(--accent-dark); border-color:var(--accent-dark); }
/* legacy aliases */
.btn-primary { background:var(--text); color:#fff; display:inline-flex; align-items:center; padding:.7rem 1.5rem; border-radius:99px; font-weight:600; font-size:.875rem; border:none; cursor:pointer; text-decoration:none; transition:all .2s; }
.btn-primary:hover { background:var(--accent-dark); transform:translateY(-1px); }
.btn-outline { background:transparent; color:var(--text); border:1.5px solid var(--border); display:inline-flex; align-items:center; padding:.7rem 1.5rem; border-radius:99px; font-weight:600; font-size:.875rem; text-decoration:none; transition:all .2s; }
.btn-outline:hover { border-color:var(--text); }

/* HERO */
.hero { position:relative; padding:5.5rem 0 4.5rem; overflow:hidden; }
.hero-bg { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.hero-blob { position:absolute; border-radius:50%; filter:blur(80px); }
.hero-blob-1 { width:600px; height:500px; background:linear-gradient(135deg,#F5D3A8,#E8B57A); right:-80px; top:-100px; opacity:.5; }
.hero-blob-2 { width:280px; height:280px; background:linear-gradient(135deg,#C09468,#8C6840); right:180px; bottom:20px; opacity:.22; }
.hero-inner { position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:4rem; align-items:center; }
.hero-eyebrow { margin-bottom:1.2rem; }
.hero h1 { margin-bottom:1.2rem; }
.hero-desc { font-size:1.05rem; color:var(--muted); max-width:44ch; line-height:1.8; margin-bottom:2rem; }
.hero-actions { display:flex; gap:.85rem; flex-wrap:wrap; }
.hero-stats { display:flex; gap:2.5rem; margin-top:3rem; padding-top:2.5rem; border-top:1px solid var(--border); }
.hero-stat strong { display:block; font-family:"Playfair Display",serif; font-size:2rem; font-weight:600; line-height:1; margin-bottom:.3rem; }
.hero-stat span { font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.hero-visual { display:flex; flex-direction:column; gap:1rem; }
.hero-img-main { border-radius:24px; overflow:hidden; aspect-ratio:4/3; background:linear-gradient(135deg,#e4c9a8,#c8a07a); }
.hero-img-main img { width:100%; height:100%; object-fit:cover; }
.hero-img-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.hero-img-sm { border-radius:16px; overflow:hidden; aspect-ratio:3/2; background:linear-gradient(135deg,#d4b596,#b8906a); }
.hero-img-sm img { width:100%; height:100%; object-fit:cover; }

/* HERO SLIDER */
.hero-slider { position:relative; width:100%; height:clamp(400px,55vw,620px); overflow:hidden; }
.slider-track { position:relative; width:100%; height:100%; }
.slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity .8s ease; }
.slide.active { opacity:1; z-index:1; }
.slide-overlay { position:absolute; inset:0; background:linear-gradient(180deg,rgba(26,23,20,.15) 0%,rgba(26,23,20,.65) 100%); }
.slide-content { position:relative; z-index:2; height:100%; display:flex; flex-direction:column; justify-content:flex-end; padding-bottom:4rem; }
.slide-content h2 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,4vw,3rem); color:#fff; max-width:20ch; line-height:1.15; margin-bottom:.5rem; }
.slide-content p { font-size:1rem; color:rgba(255,255,255,.82); max-width:42ch; line-height:1.7; }
.slider-dots { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); z-index:5; display:flex; gap:.5rem; }
.dot { width:10px; height:10px; border-radius:50%; border:2px solid rgba(255,255,255,.6); background:transparent; cursor:pointer; transition:all .25s; padding:0; }
.dot.active { background:#fff; border-color:#fff; transform:scale(1.2); }
.slider-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:5; width:44px; height:44px; border-radius:50%; border:none; background:rgba(255,255,255,.18); backdrop-filter:blur(8px); color:#fff; font-size:1.4rem; cursor:pointer; transition:background .2s; display:flex; align-items:center; justify-content:center; }
.slider-arrow:hover { background:rgba(255,255,255,.35); }
.slider-prev { left:1.2rem; }
.slider-next { right:1.2rem; }

/* SHOWCASE GRID */
.showcase-grid { display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:280px; gap:1rem; }
.showcase-grid .showcase-item:nth-child(1) { grid-column:span 2; grid-row:span 1; }
.showcase-grid .showcase-item:nth-child(4) { grid-column:span 2; grid-row:span 1; }
.showcase-item { position:relative; border-radius:20px; overflow:hidden; display:block; color:#fff; text-decoration:none; }
.showcase-img { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s cubic-bezier(.22,1,.36,1); }
.showcase-item:hover .showcase-img { transform:scale(1.06); }
.showcase-overlay { position:absolute; inset:0; background:linear-gradient(0deg,rgba(26,23,20,.72) 0%,rgba(26,23,20,.08) 50%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem; transition:background .35s; }
.showcase-item:hover .showcase-overlay { background:linear-gradient(0deg,rgba(26,23,20,.85) 0%,rgba(26,23,20,.15) 50%); }
.showcase-overlay h3 { font-family:'Playfair Display',serif; font-size:1.15rem; color:#fff; margin:.3rem 0 .2rem; }

/* FEATURED SQUARE GRID (homepage) */
.featured-square-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.featured-square-item { position:relative; display:block; border-radius:20px; overflow:hidden; aspect-ratio:1/1; color:#fff; text-decoration:none; }
.featured-square-img { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s cubic-bezier(.22,1,.36,1); }
.featured-square-item:hover .featured-square-img { transform:scale(1.05); }
.featured-square-overlay { position:absolute; inset:0; padding:1.2rem; display:flex; flex-direction:column; justify-content:flex-end; background:linear-gradient(0deg,rgba(26,23,20,.72) 0%,rgba(26,23,20,.12) 55%); transition:background .25s ease; }
.featured-square-item:hover .featured-square-overlay { background:linear-gradient(0deg,rgba(26,23,20,.82) 0%,rgba(26,23,20,.2) 60%); }
.featured-square-overlay h3 { color:#fff; font-size:1.1rem; margin:.3rem 0 .2rem; }
.featured-square-overlay span:last-child { color:rgba(255,255,255,.78); font-size:.8rem; }

/* HOMEPAGE VIDEO BAND */
.home-video-band { padding: 1rem 0 .9rem; }
.home-video-frame {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border-radius: 26px;
  min-height: clamp(260px, 40vw, 520px);
  background: #0F0D0B;
  border: 1px solid rgba(26,23,20,.14);
  box-shadow: var(--shadow-lg);
}
.home-video-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: .36;
  background: var(--home-video-poster, radial-gradient(circle at 22% 18%, #5A4A3A 0%, #16120F 62%)) center / cover no-repeat;
}
.home-video-inner {
  position: absolute;
  inset: -10% -8%;
  z-index: 1;
  pointer-events: none;
}
.home-video-inner iframe {
  width: 100%;
  height: 100%;
  border: 0;
  transform: scale(1.22);
}
.home-video-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(
    180deg,
    rgba(15,12,9,var(--home-video-overlay,.34)) 0%,
    rgba(15,12,9,calc(var(--home-video-overlay,.34) + .14)) 100%
  );
}
.home-video-ambient {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(250,250,248,.18) 0%, rgba(250,250,248,0) 18%, rgba(250,250,248,0) 82%, rgba(250,250,248,.2) 100%);
}

/* PROJECT CARDS */
.projects-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:1.25rem; }
.project-card { background:var(--card); border:1px solid var(--border); border-radius:20px; overflow:hidden; transition:box-shadow .28s ease,transform .28s ease; }
.project-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-5px); }
.project-card:nth-child(3n+1) { grid-column:span 7; }
.project-card:nth-child(3n+2) { grid-column:span 5; }
.project-card:nth-child(3n) { grid-column:span 5; }
.project-card:nth-child(3n-1) { grid-column:span 7; }
.project-thumb { aspect-ratio:16/9; background:linear-gradient(135deg,#e8d5bc,#c8a87e); overflow:hidden; }
.project-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.project-card:hover .project-thumb img { transform:scale(1.04); }
.project-body { padding:1.4rem; }
.project-body .eyebrow { margin-bottom:.5rem; }
.project-body h3 { margin-bottom:.5rem; font-size:1.15rem; }
.project-body p { font-size:.875rem; color:var(--muted); line-height:1.65; }
.project-link { display:inline-flex; align-items:center; gap:.35rem; margin-top:.9rem; font-size:.8rem; font-weight:700; color:var(--accent-dark); }
.project-link::after { content:'→'; transition:transform .2s; }
.project-link:hover::after { transform:translateX(4px); }

/* UNIFORM PROJECT CARDS (projects page) */
.project-uniform-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.project-ucard { display:flex; flex-direction:column; background:var(--card); border:1px solid var(--border); border-radius:18px; overflow:hidden; color:inherit; transition:box-shadow .3s ease,transform .3s ease; cursor:pointer; }
.project-ucard:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.project-ucard-img { position:relative; aspect-ratio:4/3; overflow:hidden; background:#f0ebe3; }
.project-ucard-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .45s cubic-bezier(.22,1,.36,1), opacity .18s ease; }
.project-ucard:hover .project-ucard-img img { transform:scale(1.03); }
.pcard-main-link { display:flex; flex-direction:column; flex:1; text-decoration:none; color:inherit; }
.project-ucard-body { padding:1.2rem 1.4rem 1.4rem; display:flex; flex-direction:column; gap:.35rem; flex:1; }
.project-ucard-body h3 { font-size:1.1rem; margin:0; }
.project-ucard-meta { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:.5rem; font-size:.78rem; color:var(--muted); }
.project-ucard-arrow { font-weight:700; color:var(--accent-dark); transition:transform .2s; }
.project-ucard:hover .project-ucard-arrow { transform:translateX(3px); }
/* Overlay img shown when hovering strip thumbnails (sits above <picture>) */
.pcard-hover-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity .22s ease; pointer-events:none; z-index:1; }
.pcard-hover-img.is-visible { opacity:1; }
/* Hover overlay (inside image area) */
.pcard-overlay { position:absolute; inset:0; z-index:2; background:linear-gradient(to top, rgba(6,5,4,.78) 0%, rgba(6,5,4,.18) 55%, transparent 100%); opacity:0; transition:opacity .25s; display:flex; flex-direction:column; justify-content:flex-end; padding:.65rem .7rem; gap:.55rem; pointer-events:none; }
.project-ucard:hover .pcard-overlay { opacity:1; pointer-events:auto; }
/* Thumbnail strip */
.pcard-strip { display:flex; gap:5px; overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none; }
.pcard-strip::-webkit-scrollbar { display:none; }
.pcard-strip-thumb { flex-shrink:0; width:46px; height:34px; border-radius:5px; overflow:hidden; cursor:pointer; border:1.5px solid rgba(255,255,255,.3); background:rgba(0,0,0,.25); padding:0; transition:border-color .15s,transform .15s; }
.pcard-strip-thumb.is-active,.pcard-strip-thumb:hover { border-color:#fff; transform:scale(1.08); }
.pcard-strip-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
/* İncele button inside overlay */
.pcard-overlay-incele { align-self:flex-start; display:inline-flex; align-items:center; gap:.3rem; font-size:.77rem; font-weight:700; color:#fff; background:rgba(255,255,255,.16); backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.28); border-radius:99px; padding:.36rem .88rem; text-decoration:none; transition:background .18s; white-space:nowrap; }
.pcard-overlay-incele:hover { background:rgba(255,255,255,.28); }
/* Quick preview button (top-right of image) */
.pcard-preview-btn { position:absolute; top:9px; right:9px; z-index:4; width:30px; height:30px; border-radius:7px; background:rgba(8,6,4,.55); backdrop-filter:blur(5px); -webkit-backdrop-filter:blur(5px); border:1px solid rgba(255,255,255,.2); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; transition:opacity .2s,background .18s; padding:0; }
.project-ucard:hover .pcard-preview-btn { opacity:1; }
.pcard-preview-btn:hover { background:rgba(8,6,4,.82); }
/* Project image preview modal */
#pcard-modal { display:none; position:fixed; inset:0; z-index:9998; background:rgba(6,5,4,.88); padding:1.5rem 1rem; overflow-y:auto; }
#pcard-modal.is-open { display:block; }
.pcard-modal-wrap { max-width:860px; margin:0 auto; background:var(--card); border-radius:22px; overflow:hidden; box-shadow:0 24px 64px rgba(0,0,0,.5); }
.pcard-modal-head { display:flex; align-items:center; justify-content:space-between; padding:1.1rem 1.4rem; border-bottom:1px solid var(--border); gap:.8rem; }
.pcard-modal-head-title { font-size:1rem; font-weight:700; margin:0; flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pcard-modal-close { width:34px; height:34px; border-radius:99px; background:var(--border); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:1.15rem; color:var(--text); flex-shrink:0; transition:background .15s; }
.pcard-modal-close:hover { background:rgba(26,23,20,.18); }
.pcard-modal-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:4px; padding:4px; }
/* Portrait-safe: fixed row height + contain — no squishing */
.pcard-modal-item { display:flex; align-items:center; justify-content:center; background:#161210; height:200px; text-decoration:none; overflow:hidden; }
.pcard-modal-item img { max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; display:block; transition:transform .22s; }
.pcard-modal-item:hover img { transform:scale(1.04); }
.pcard-modal-foot { display:flex; align-items:center; justify-content:flex-end; gap:.8rem; padding:1rem 1.4rem; border-top:1px solid var(--border); }
.pcard-modal-detail { display:inline-flex; align-items:center; gap:.4rem; padding:.55rem 1.4rem; background:var(--accent); color:#fff; border-radius:99px; font-size:.875rem; font-weight:700; text-decoration:none; transition:background .18s; }
.pcard-modal-detail:hover { background:var(--accent-dark); }
/* Fullscreen image lightbox (modal gallery) */
#pcard-lightbox { display:none; position:fixed; inset:0; z-index:10000; background:rgba(0,0,0,.95); touch-action:pan-y; }
#pcard-lightbox.is-open { display:flex; align-items:center; justify-content:center; }
.pcl-img-wrap { display:flex; align-items:center; justify-content:center; max-width:94vw; max-height:92vh; }
.pcl-img { max-width:94vw; max-height:92vh; width:auto; height:auto; object-fit:contain; display:block; user-select:none; pointer-events:none; }
.pcl-close { position:fixed; top:14px; right:16px; z-index:10001; width:38px; height:38px; border-radius:99px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); color:#fff; font-size:1.4rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .15s; }
.pcl-close:hover { background:rgba(255,255,255,.24); }
.pcl-nav { position:fixed; top:50%; transform:translateY(-50%); z-index:10001; width:44px; height:60px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); border-radius:10px; color:#fff; font-size:1.6rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .15s; }
.pcl-nav:hover { background:rgba(255,255,255,.22); }
.pcl-prev { left:12px; }
.pcl-next { right:12px; }
.pcl-counter { position:fixed; bottom:16px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.7); font-size:.82rem; background:rgba(0,0,0,.4); padding:.3rem .9rem; border-radius:99px; }

/* BLOG CARDS */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.25rem; }
.blog-card { background:var(--card); border:1px solid var(--border); border-radius:20px; overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .25s,transform .25s; }
.blog-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); }
.blog-card-body { padding:1.4rem; flex:1; display:flex; flex-direction:column; gap:.6rem; }
.blog-card h3 { font-size:1.1rem; }
.blog-card p { font-size:.875rem; color:var(--muted); line-height:1.65; flex:1; }
.blog-read { font-size:.8rem; font-weight:700; color:var(--accent-dark); display:inline-flex; align-items:center; gap:.3rem; margin-top:.5rem; }

/* BLOG DETAIL GALLERY */
.blog-gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:.85rem; margin-top:1.5rem; }
.blog-gallery-item { border-radius:14px; overflow:hidden; border:1px solid var(--border); background:#f4efe8; }
.blog-gallery-item img { width:100%; height:100%; aspect-ratio:4/3; object-fit:cover; display:block; }

/* BLOG INDEX — filter bar */
.blog-filter-bar { position:relative; margin-bottom:1.6rem; }
.blog-filter-cats { display:flex; flex-wrap:wrap; gap:.45rem .4rem; padding-bottom:.3rem; }
.blog-filter-cat { display:inline-flex; align-items:center; gap:.4rem; padding:.42rem .95rem; border:1.5px solid var(--border); border-radius:99px; font-size:.8rem; font-weight:600; color:var(--muted); transition:all .18s; text-decoration:none; }
.blog-filter-cat:hover { border-color:var(--text); color:var(--text); }
.blog-filter-cat.is-active { background:var(--text); color:#fff; border-color:var(--text); }
.blog-filter-cat-count { font-size:.7rem; background:rgba(0,0,0,.07); border-radius:99px; padding:.1rem .45rem; font-weight:700; }
.blog-filter-cat.is-active .blog-filter-cat-count { background:rgba(255,255,255,.22); }
.blog-empty { grid-column:1/-1; text-align:center; color:var(--muted); padding:4rem 0; font-size:.95rem; }
/* Infinite scroll loader */
#blog-sentinel { height:1px; }
#blog-loader { display:none; justify-content:center; align-items:center; padding:2.4rem 0; }
.blog-loader-spinner { width:34px; height:34px; border:3px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .7s linear infinite; }
.blog-tag-cloud { margin-top:2.5rem; padding-top:1.8rem; border-top:1px solid var(--border); }

/* BLOG DETAIL LAYOUT */
.blog-show-wrap { max-width:min(1120px, 96vw); }
/* Blog post page-head no cover: coloured gradient fallback */
.page-head-no-cover { background:linear-gradient(135deg,#F2E8DB 0%,#FDFAF6 50%,#EDE0D0 100%); }
/* Blog post head inner: left-aligned content with max-width */
.blog-post-head-inner { max-width:min(780px,100%); }
.blog-post-head-inner .blog-article-title { color:var(--text); font-size:clamp(1.7rem,4vw,2.5rem); text-align:left; margin-top:.75rem; }
.blog-post-head-inner .blog-article-excerpt { color:var(--muted); font-size:1rem; text-align:left; margin:0; margin-top:.5rem; max-width:none; }
.page-head-has-media .blog-post-head-inner .blog-article-title { color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.35); }
.page-head-has-media .blog-post-head-inner .blog-article-excerpt { color:rgba(255,255,255,.88); }
.page-head-has-media .blog-article-meta { --blog-meta-color:rgba(255,255,255,.75); }
.blog-article-meta { display:flex; align-items:center; flex-wrap:wrap; gap:.6rem; margin-top:1rem; }
.blog-article-back { display:inline-flex; align-items:center; gap:.3rem; font-size:.78rem; color:var(--muted); text-decoration:none; opacity:.75; transition:opacity .15s; margin-top:.9rem; }
.blog-article-back:hover { opacity:1; }
.page-head-has-media .blog-article-back { color:rgba(255,255,255,.75); }
/* Breadcrumb */
.blog-breadcrumb { display:flex; align-items:center; flex-wrap:wrap; gap:.35rem; font-size:.8rem; color:var(--muted); margin-bottom:1.6rem; }
.blog-breadcrumb a { color:var(--muted); text-decoration:none; display:inline-flex; align-items:center; gap:.3rem; }
.blog-breadcrumb a:hover { color:var(--text); }
.blog-breadcrumb > span { opacity:.45; }
.blog-breadcrumb-current { color:var(--text); font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:280px; }
/* Article meta elements */
.blog-article-category { display:inline-block; padding:.25rem .9rem; background:var(--accent); color:#fff; border-radius:99px; font-size:.72rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; text-decoration:none; }
.page-head-has-media .blog-article-category { background:rgba(255,255,255,.22); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.35); }
.blog-article-date { font-size:.78rem; color:var(--muted); }
.blog-article-reading-time { font-size:.75rem; color:var(--muted); padding:.2rem .65rem; border:1px solid var(--border); border-radius:99px; }
.page-head-has-media .blog-article-date,.page-head-has-media .blog-article-reading-time { color:rgba(255,255,255,.75); border-color:rgba(255,255,255,.3); }
/* Cover media */
.blog-cover-media {
  border-radius: 22px;
  overflow: hidden;
  margin-bottom: 2.5rem;
  border: 1px solid var(--border);
  background: #f4efe8;
  box-shadow: var(--shadow-md);
}
.blog-cover-media img {
  width: 100%;
  height: min(52vw, 540px);
  min-height: 260px;
  object-fit: cover;
  display: block;
}
/* Article body */
.blog-article-body { margin-bottom:2.5rem; }
.blog-article-content { line-height:1.9; font-size:1.05rem; max-width:min(800px,100%); }
.blog-article-content h2 { font-size:1.5rem; margin:2rem 0 .7rem; font-family:'Playfair Display',serif; }
.blog-article-content h3 { font-size:1.2rem; margin:1.6rem 0 .5rem; }
.blog-article-content p { margin-bottom:1.2rem; }
.blog-article-content ul,.blog-article-content ol { padding-left:1.5rem; margin-bottom:1.2rem; }
.blog-article-content li { margin-bottom:.4rem; }
.blog-article-content strong { font-weight:700; color:var(--text); }
.blog-article-content img { max-width:100%; border-radius:14px; margin:1rem 0; }
.blog-article-content blockquote { border-left:4px solid var(--accent); margin:1.5rem 0; padding:.8rem 1.2rem; background:var(--card); border-radius:0 12px 12px 0; color:var(--muted); font-style:italic; }
.table-responsive { overflow-x:auto; -webkit-overflow-scrolling:touch; margin:1.5rem 0; border-radius:12px; border:1px solid var(--border); }
.blog-article-content .table-responsive { margin:1.5rem 0; }
.blog-article-content table { width:100%; border-collapse:collapse; font-size:.93rem; min-width:380px; }
.blog-article-content thead { background:var(--card,#f5f0eb); }
.blog-article-content th { padding:.7rem 1.05rem; text-align:left; font-weight:700; color:var(--text); border-bottom:2px solid var(--border); white-space:nowrap; }
.blog-article-content td { padding:.65rem 1.05rem; border-bottom:1px solid var(--border); vertical-align:top; line-height:1.5; }
.blog-article-content tbody tr:last-child td { border-bottom:0; }
.blog-article-content tbody tr:nth-child(even) { background:var(--card,#f9f6f2); }
.blog-article-content tbody tr:hover { background:rgba(139,90,43,.06); }
/* Tags */
.blog-article-tags { margin:0 0 1.5rem; padding-top:1.5rem; border-top:1px solid var(--border); display:flex; flex-wrap:wrap; gap:.4rem; }
.blog-tag-pill { padding:.28rem .7rem; border:1.5px solid var(--border); border-radius:99px; font-size:.77rem; color:var(--muted); text-decoration:none; transition:all .15s; }
.blog-tag-pill:hover { border-color:var(--text); color:var(--text); }
/* CTA box */
.blog-cta-box { display:grid; grid-template-columns:1fr auto; gap:1.5rem; align-items:center; padding:2rem 2.2rem; background:var(--card); border:1px solid var(--border); border-radius:22px; margin:2.5rem auto; max-width:min(780px,100%); }
.blog-cta-text h3 { font-family:'Playfair Display',serif; font-size:1.15rem; margin-bottom:.35rem; }
.blog-cta-text p { color:var(--muted); font-size:.875rem; margin:0; }
/* External Gallery CTA Band (on /projeler) */
.ext-gallery-cta-band { background:linear-gradient(135deg,var(--accent) 0%,#8b5c2b 100%); margin:3rem 0 0; padding:2.8rem 0; }
.ext-gallery-cta-inner { display:grid; grid-template-columns:auto 1fr auto; gap:1.8rem; align-items:center; }
.ext-gallery-cta-icon { width:64px; height:64px; background:rgba(255,255,255,.15); border-radius:16px; display:flex; align-items:center; justify-content:center; color:#fff; flex-shrink:0; }
.ext-gallery-cta-text h2 { font-family:'Playfair Display',serif; font-size:clamp(1.15rem,2.5vw,1.5rem); color:#fff; margin-bottom:.35rem; }
.ext-gallery-cta-text p { color:rgba(255,255,255,.82); font-size:.9rem; margin:0; }
.ext-gallery-cta-btn { background:#fff !important; color:var(--accent) !important; border-color:#fff !important; font-weight:700; display:inline-flex; align-items:center; gap:.4rem; flex-shrink:0; }
.ext-gallery-cta-btn:hover { background:rgba(255,255,255,.92) !important; }
/* External Gallery Page */
.ext-gallery-wrap { min-height:60vh; }
.ext-gallery-hero { background:linear-gradient(135deg,#100c0a 0%,#2a1608 55%,#3b2210 100%); padding:3.5rem 0 3rem; margin-bottom:3rem; }
.ext-gallery-hero h1 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,4vw,2.8rem); color:#fff; margin:.4rem 0 .75rem; }
.ext-gallery-hero-desc { color:rgba(255,255,255,.72); font-size:1rem; margin:0; max-width:600px; }
.ext-gallery-count { display:inline-block; margin-top:1.1rem; font-size:.8rem; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); color:rgba(255,255,255,.85); padding:.3rem .85rem; border-radius:99px; letter-spacing:.02em; }
/* Masonry grid */
.ext-gallery-masonry { columns:4 200px; gap:.55rem; margin-bottom:3rem; }
/* Individual item */
.ext-gallery-item { display:block; break-inside:avoid; margin-bottom:.55rem; border-radius:10px; overflow:hidden; cursor:zoom-in; position:relative; background:var(--card); text-decoration:none; }
/* Image — direct src with native lazy load */
.ext-gallery-item img { width:100%; height:auto; display:block; transition:transform .35s ease; }
/* Hover overlay */
.ext-gallery-overlay { position:absolute; inset:0; background:rgba(0,0,0,.38); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .25s; border-radius:10px; }
.ext-gallery-item:hover .ext-gallery-overlay { opacity:1; }
.ext-gallery-item:hover img { transform:scale(1.05); }
/* Empty state */
.ext-gallery-empty { text-align:center; padding:5rem 1rem; color:var(--muted); }
.ext-gallery-empty svg { opacity:.35; margin-bottom:1rem; }
.ext-gallery-back-wrap { text-align:center; margin-top:2rem; padding-bottom:4rem; }
/* Related posts */
.blog-related { margin-top:2.5rem; padding-top:2rem; border-top:1px solid var(--border); }
.blog-related-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.blog-related-card { background:var(--card); border:1px solid var(--border); border-radius:18px; overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .2s,transform .2s; }
.blog-related-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.blog-related-img { display:block; aspect-ratio:16/9; overflow:hidden; }
.blog-related-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.blog-related-card:hover .blog-related-img img { transform:scale(1.04); }
.blog-related-body { padding:1rem; flex:1; display:flex; flex-direction:column; gap:.35rem; }
.blog-related-body h3 { font-size:.92rem; line-height:1.4; margin:0; }
.blog-related-body h3 a { color:inherit; text-decoration:none; }
.blog-related-body h3 a:hover { color:var(--accent-dark); }
/* Gallery */
.blog-article-gallery { margin-bottom:2rem; }

/* FILTERS */
.filters { display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:2.5rem; }
.chip { padding:.45rem 1rem; border:1.5px solid var(--border); border-radius:99px; font-size:.8rem; font-weight:600; color:var(--muted); transition:all .18s; }
.chip:hover { border-color:var(--text); color:var(--text); }
.chip.active { background:var(--text); color:#fff; border-color:var(--text); }

/* GALLERY */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1rem; }
.gallery-item { aspect-ratio:4/3; border-radius:14px; overflow:hidden; cursor:pointer; background:#f0ebe3; border:1px solid var(--border); }
.gallery-item img { width:100%; height:100%; object-fit:cover; display:block; transition:opacity .3s ease; }
.gallery-item:hover img { opacity:.92; }

/* BEFORE/AFTER */
.ba-wrap { position:relative; overflow:hidden; border-radius:20px; aspect-ratio:16/9; cursor:ew-resize; user-select:none; border:1px solid var(--border); }
.ba-before,.ba-after { position:absolute; inset:0; }
.ba-before img,.ba-after img { width:100%; height:100%; object-fit:cover; }
.ba-after { clip-path:inset(0 50% 0 0); }
.ba-divider { position:absolute; top:0; bottom:0; left:var(--ba-split,50%); width:2px; background:#fff; pointer-events:none; transform:translateX(-50%); }
.ba-handle { position:absolute; top:50%; left:var(--ba-split,50%); transform:translate(-50%,-50%); width:44px; height:44px; background:#fff; border-radius:50%; box-shadow:0 4px 18px rgba(0,0,0,.22); display:flex; align-items:center; justify-content:center; pointer-events:none; font-size:.9rem; color:var(--text); }
.ba-range { position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; -webkit-appearance:none; appearance:none; }
/* legacy ba support */
.ba-image-wrap { position:relative; border-radius:16px; overflow:hidden; }
.ba-image-wrap img { width:100%; border-radius:0; }

/* APPROACH */
.approach-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:1rem; }
.approach-card { background:var(--card); border:1px solid var(--border); border-radius:18px; padding:1.5rem; }
.approach-num { width:40px; height:40px; background:var(--accent); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.85rem; margin-bottom:1rem; }
.approach-card h3 { font-size:1rem; margin-bottom:.4rem; }
.approach-card p { font-size:.875rem; color:var(--muted); line-height:1.65; }
/* legacy */
.approach-list { list-style:none; padding:0; display:grid; gap:.8rem; }
.split { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }

/* PAGE HERO */
.page-hero { padding:4.5rem 0 3.5rem; border-bottom:1px solid var(--border); margin-bottom:3.5rem; }
.page-head {
  --ph-accent: #C09468;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: 2.2rem 2.3rem;
  margin: 1rem 0 2.5rem;
  border: 1px solid var(--border);
  border-radius: 26px;
  background: linear-gradient(130deg, #F7EFE4 0%, #FFFFFF 56%, #F2E8DB 100%);
  box-shadow: var(--shadow);
}
.page-head::before,
.page-head::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: -1;
}
.page-head::before {
  width: 320px;
  height: 320px;
  right: -130px;
  top: -170px;
  background: radial-gradient(circle, rgba(192,148,104,.3) 0%, transparent 72%);
}
.page-head::after {
  width: 260px;
  height: 260px;
  left: -120px;
  bottom: -150px;
  background: radial-gradient(circle, rgba(26,23,20,.08) 0%, transparent 70%);
}
.page-head .eyebrow { margin-bottom: .7rem; }
.page-head > h1 { margin-bottom: .85rem; }
.page-head > p { color: var(--muted); max-width: 64ch; line-height: 1.8; }
.page-head-centered { text-align: center; }
.page-head-centered .page-head-badge { margin-left: auto; margin-right: auto; }
.page-head-centered > p,
.page-head-centered > h1 {
  max-width: 36ch;
  margin-left: auto;
  margin-right: auto;
}
.page-head-centered > p {
  max-width: 64ch;
}
.page-head-badge {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .85rem;
  font-size: 1.05rem;
  color: #fff;
  background: var(--ph-accent);
  box-shadow: 0 8px 20px rgba(26,23,20,.16);
}
.page-head-services { --ph-accent: #9C6D43; background: linear-gradient(130deg, #F8EFE3 0%, #FFFFFF 54%, #F2E2CC 100%); }
.page-head-process { --ph-accent: #7C6C5A; background: linear-gradient(130deg, #F2EEE7 0%, #FFFFFF 56%, #EAE2D5 100%); }
.page-head-contact { --ph-accent: #8E7866; background: linear-gradient(130deg, #F6EDE3 0%, #FFFFFF 56%, #F1E4D5 100%); }
.page-head-about { --ph-accent: #7A6150; background: linear-gradient(130deg, #F4ECE6 0%, #FFFFFF 56%, #EDE0D3 100%); }
.page-head-projects { --ph-accent: #81624A; background: linear-gradient(130deg, #F6EEE6 0%, #FFFFFF 55%, #EEE1D5 100%); }
.page-head-blog { --ph-accent: #6D6054; background: linear-gradient(130deg, #F2EEEA 0%, #FFFFFF 55%, #E9E2DB 100%); }
.page-head-custom { --ph-accent: #7D5C42; background: linear-gradient(130deg, #F7EEE4 0%, #FFFFFF 55%, #EFE3D7 100%); }
.page-head-404 { --ph-accent: #8A4B4B; max-width: min(940px, 92vw); margin: 2.2rem auto; }
.page-head-has-media {
  color: #FDFBF8;
  border-color: rgba(255,255,255,.18);
  background:
    linear-gradient(180deg, rgba(12,10,8,var(--page-head-overlay,.58)) 0%, rgba(12,10,8,.72) 100%),
    var(--page-head-bg) center / cover no-repeat;
  box-shadow: 0 16px 44px rgba(26,23,20,.22);
  min-height: clamp(260px, 28vw, 340px);
}
.page-head-has-media::before,
.page-head-has-media::after { display: none; }
.page-head-has-media .eyebrow { color: rgba(255,255,255,.86); }
.page-head-has-media > h1 { color: rgba(255,255,255,.94); font-family:'Playfair Display',serif; font-size:clamp(2rem,4vw,3rem); }
.page-head-has-media > p { color: rgba(255,255,255,.94); }
.page-head-has-media .page-head-badge {
  background: rgba(255,255,255,.2);
  border: 1px solid rgba(255,255,255,.36);
  color: #fff;
  box-shadow: none;
}

/* CONTENT */
.content-body { background:var(--card); border:1px solid var(--border); border-radius:20px; padding:2rem; line-height:1.8; font-size:.975rem; color:var(--muted); }
.content-body h2,.content-body h3 { margin:1.5rem 0 .5rem; color:var(--text); }
.content-body p { margin-bottom:1rem; }
.content-body img,
.content-body iframe,
.content-body video,
.content-body canvas,
.content-body svg {
  max-width: 100%;
  height: auto;
}
.content-body img {
  display: block;
  border-radius: 14px;
  margin: 1rem auto;
}
.content-section-media { margin: .9rem 0 1.1rem; }
.content-section-media img {
  width: 100%;
  border-radius: 14px;
  object-fit: cover;
  max-height: min(66vw, 440px);
}
.content-section-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill,minmax(180px,1fr));
  gap: .65rem;
  margin: .8rem 0 1.1rem;
}
.content-section-gallery a {
  display: block;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: #F5F1EB;
  cursor: zoom-in;
}
.content-section-gallery img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  margin: 0;
  border-radius: 0;
}

/* CONTACT */
.contact-grid { display:grid; grid-template-columns:1.25fr .75fr; gap:2rem; align-items:start; }
.contact-card { background:var(--card); border:1px solid var(--border); border-radius:20px; padding:2rem; }
.form-group { display:grid; gap:.4rem; margin-bottom:1.1rem; }
.form-group label { font-size:.78rem; font-weight:700; letter-spacing:.05em; color:var(--text); text-transform:uppercase; }
.form-group input,.form-group textarea,.form-group select { width:100%; padding:.7rem 1rem; border:1.5px solid var(--border); border-radius:12px; font-family:"Manrope",sans-serif; font-size:.9rem; background:#fff; color:var(--text); outline:none; transition:border-color .2s; }
.form-group input:focus,.form-group textarea:focus { border-color:var(--accent); }
/* legacy form */
label { display:grid; gap:.35rem; font-weight:500; font-size:.875rem; }
input:not([type=checkbox]):not([type=radio]),textarea,select { width:100%; padding:.65rem .9rem; border-radius:12px; border:1.5px solid var(--border); background:#fff; font-family:"Manrope",sans-serif; font-size:.875rem; outline:none; transition:border-color .2s; }
input:focus,textarea:focus { border-color:var(--accent); }

/* SERVICES */
.services-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.25rem; }
.service-card { background:var(--card); border:1px solid var(--border); border-radius:20px; padding:1.8rem; transition:box-shadow .25s,transform .25s; }
.service-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.service-icon { width:48px; height:48px; border-radius:14px; background:linear-gradient(135deg,#F5D3A8,#C09468); margin-bottom:1.1rem; }
.service-card h3 { font-size:1.1rem; margin-bottom:.5rem; }
.service-card p { font-size:.875rem; color:var(--muted); line-height:1.7; }
.services-grid-rich { grid-template-columns:repeat(3,minmax(0,1fr)); gap:1.35rem; margin-bottom:1.8rem; align-items:stretch; }
.service-media-card { padding:0; overflow:hidden; display:flex; flex-direction:column; }
.service-media-wrap { aspect-ratio:3/4; overflow:hidden; background:#EDE4D9; }
.service-media-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .45s cubic-bezier(.22,1,.36,1); }
.service-media-card:hover .service-media-wrap img { transform:scale(1.04); }
.service-card-body { padding:1.2rem 1.25rem 1.4rem; display:grid; align-content:start; gap:.45rem; }
.service-tag {
  display:inline-flex;
  align-items:center;
  padding:.2rem .62rem;
  border-radius:99px;
  margin-bottom:.2rem;
  font-size:.68rem;
  letter-spacing:.12em;
  font-weight:700;
  text-transform:uppercase;
  color:var(--accent-dark);
  background:rgba(192,148,104,.15);
}
.service-card-body h3 { margin:0; line-height:1.3; }
.service-card-body p { margin-top:.15rem; }
.services-cta-band {
  margin: 4.4rem 0 0;
  padding: 2.4rem;
  background: linear-gradient(140deg,#1F1A16 0%, #3A2F26 100%);
  border-radius: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.5rem;
  align-items: center;
  color: #FAF7F3;
}
.services-cta-band h3 { color:#fff; font-size:1.45rem; margin-bottom:.55rem; }
.services-cta-band p { color:rgba(250,247,243,.78); max-width:60ch; }

/* FOOTER */
.main-footer { background:var(--text); color:#E9E4DC; padding:4rem 0 2rem; margin-top:3.4rem; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.footer-brand p { margin-top:1rem; font-size:.875rem; color:#A8A29E; line-height:1.75; }
.footer-title { font-size:.68rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:#79746E; margin-bottom:1rem; }
.footer-links { display:grid; gap:.5rem; }
.footer-links a { font-size:.875rem; color:#D6D3D1; transition:color .2s; }
.footer-links a:hover { color:#fff; }
.footer-bottom { padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.08); display:flex; justify-content:space-between; align-items:center; font-size:.8rem; color:#79746E; }
/* legacy footer */
.footer-link-list { display:grid; gap:.3rem; }

/* COOKIE BANNER */
.cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 220;
  background: rgba(20,17,14,.96);
  border-top: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
}
.cookie-banner-inner {
  min-height: 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .95rem 0;
}
.cookie-banner-text {
  font-size: .84rem;
  color: rgba(246,241,232,.9);
  line-height: 1.65;
  max-width: 76ch;
}
.cookie-banner-actions {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}
.cookie-banner .btn-ghost {
  color: rgba(246,241,232,.9);
  border-color: rgba(255,255,255,.22);
}
.cookie-banner .btn-ghost:hover {
  color: #fff;
  border-color: rgba(255,255,255,.55);
  background: rgba(255,255,255,.08);
}

/* FLASH */
.flash { padding:.9rem 1.2rem; border-radius:12px; margin-bottom:1.5rem; font-size:.9rem; font-weight:500; }
.flash.success { background:#ECFDF5; color:#065F46; border:1px solid #A7F3D0; }
.flash.error { background:#FEF2F2; color:#991B1B; border:1px solid #FECACA; }

/* PROCESS TIMELINE */
.process-highlight-grid {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
}
.process-highlight-card {
  background: linear-gradient(145deg,#F7EFE5 0%, #FFFFFF 72%);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1rem 1rem 1.05rem;
}
.process-highlight-label {
  font-size: .66rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: .35rem;
}
.process-highlight-card h3 {
  font-size: 1.35rem;
  margin-bottom: .35rem;
}
.process-highlight-card p {
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.65;
}
.process-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.2rem;
  align-items: start;
}
.process-timeline-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 1.2rem 1.2rem .6rem;
}
.process-timeline-head { margin-bottom: 1rem; }
.process-timeline-head h2 { margin: .35rem 0 .45rem; }
.process-timeline-head p {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.7;
  max-width: 60ch;
}
.process-timeline { max-width:700px; margin:0 auto; position:relative; }
.process-step { display:flex; gap:1.5rem; align-items:flex-start; position:relative; padding-bottom:2.5rem; }
.process-step:last-child { padding-bottom:0; }
.process-step-icon { width:56px; height:56px; border-radius:16px; display:flex; align-items:center; justify-content:center; flex-shrink:0; position:relative; z-index:2; }
.process-step-line { position:absolute; left:28px; top:56px; bottom:0; width:2px; background:var(--border); z-index:1; }
.process-step:last-child .process-step-line { display:none; }
.process-step-content { padding-top:.3rem; flex:1; }
.process-side-panel {
  position: sticky;
  top: calc(var(--nav-h) + 1.2rem);
  background: linear-gradient(155deg,#1F1A16 0%,#2B241D 100%);
  color: #F6F0E8;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  padding: 1.1rem 1rem;
}
.process-side-panel .eyebrow { color: rgba(246,240,232,.72); }
.process-side-panel h3 {
  color: #fff;
  font-size: 1.15rem;
  margin: .45rem 0 .85rem;
}
.process-side-list { display: grid; gap: .75rem; margin-bottom: .95rem; }
.process-side-list h4 {
  font-family: 'Manrope', sans-serif;
  font-size: .88rem;
  line-height: 1.35;
  margin-bottom: .2rem;
}
.process-side-list p {
  font-size: .78rem;
  line-height: 1.55;
  color: rgba(246,240,232,.78);
}

/* LEGAL */
.legal-text {
  color: var(--muted);
  line-height: 1.9;
  font-size: .93rem;
}

/* FAQ */
.faq-item { border:1px solid var(--border); border-radius:14px; margin-bottom:.75rem; overflow:hidden; transition:box-shadow .25s; }
.faq-item[open] { box-shadow:0 4px 20px rgba(0,0,0,.06); }
.faq-q { padding:1.2rem 1.5rem; font-weight:600; font-size:.95rem; cursor:pointer; list-style:none; display:flex; align-items:center; justify-content:space-between; gap:1rem; user-select:none; }
.faq-q::-webkit-details-marker { display:none; }
.faq-q::after { content:'+'; font-size:1.3rem; color:var(--muted); transition:transform .25s; flex-shrink:0; }
.faq-item[open] .faq-q::after { content:'\2212'; transform:rotate(180deg); }
.faq-a { padding:0 1.5rem 1.2rem; }
.faq-a p { color:var(--muted); font-size:.9rem; line-height:1.75; margin:0; }

/* BEFORE/AFTER SHOWCASE (homepage) */
.ba-showcase-section { padding:5rem 0; background:linear-gradient(180deg,var(--bg) 0%,#F0EBE3 50%,var(--bg) 100%); }
.ba-showcase-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,480px),1fr)); gap:2rem; }
.ba-showcase-card { transition:transform .3s ease,box-shadow .3s ease; }
.ba-showcase-card:hover { transform:translateY(-4px); }
.ba-showcase-card .ba-wrap { box-shadow:var(--shadow-md); border:1px solid var(--border); }
.ba-showcase-card:hover .ba-wrap { box-shadow:var(--shadow-lg); }
.ba-label { position:absolute; top:.75rem; z-index:3; padding:.25rem .7rem; border-radius:99px; font-size:.65rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; pointer-events:none; backdrop-filter:blur(8px); }
.ba-label-before { left:.75rem; background:rgba(26,23,20,.6); color:#fff; }
.ba-label-after { right:.75rem; background:rgba(192,148,104,.75); color:#fff; }
.ba-showcase-info { padding:.9rem .2rem .3rem; }
.ba-showcase-title { font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:600; color:var(--text); transition:color .2s; }
.ba-showcase-title:hover { color:var(--accent); }
.ba-showcase-caption { font-size:.82rem; color:var(--muted); margin-top:.2rem; }

/* HOMEPAGE REFERENCES */
.references-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:1rem; }
.reference-card { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:1rem; transition:transform .25s ease, box-shadow .25s ease; }
.reference-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.reference-image-wrap { border-radius:12px; overflow:hidden; background:#f4efe8; margin-bottom:.7rem; }
.reference-image-wrap img { width:100%; height:100%; aspect-ratio:16/10; object-fit:cover; display:block; }
.reference-card h3 { font-size:.95rem; margin:0; color:var(--text); }

/* INSTAGRAM FEED */
.instagram-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.instagram-card { background:var(--card); border:1px solid var(--border); border-radius:16px; overflow:hidden; }
.instagram-media { display:block; aspect-ratio:1/1; background:#f2ede6; }
.instagram-media img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .28s ease; }
.instagram-card:hover .instagram-media img { transform:scale(1.03); }
.instagram-post-link { display:block; padding:.75rem .9rem; font-size:.8rem; font-weight:700; color:var(--accent-dark); border-top:1px solid var(--border); }
.instagram-actions { margin-top:1.25rem; display:flex; gap:.75rem; align-items:center; justify-content:center; flex-wrap:wrap; }
.instagram-follow-btn { gap:.45rem; }
.instagram-follow-btn svg { width:16px; height:16px; }

/* SOCIAL ICONS */
.social-icons { display:flex; gap:.75rem; align-items:center; }
.social-icon { display:flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:50%; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.1); color:#D6D3D1; transition:all .25s; }
.social-icon:hover { background:var(--accent); border-color:var(--accent); color:#fff; transform:translateY(-2px); }
.social-icon svg { width:18px; height:18px; }

/* FLOATING WHATSAPP */
.whatsapp-float { position:fixed; bottom:1.4rem; right:1.4rem; z-index:90; border-radius:999px; background:var(--accent); color:#fff; display:inline-flex; align-items:center; gap:.5rem; padding:.75rem 1rem .75rem .85rem; font-weight:700; font-size:.85rem; box-shadow:0 8px 24px rgba(0,0,0,.18); transition:transform .2s ease,box-shadow .2s ease,opacity .25s ease,visibility .25s; }
.whatsapp-float:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(0,0,0,.24); }
.whatsapp-float.wa-hidden { opacity:0; visibility:hidden; pointer-events:none; }
.wa-icon { width:22px; height:22px; display:inline-flex; align-items:center; justify-content:center; }
.wa-icon svg { width:100%; height:100%; }
.wa-text { line-height:1; white-space:nowrap; }

/* REVEAL ANIMATION */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1); }
.reveal.is-visible { opacity:1; transform:translateY(0); }

/* RESPONSIVE */
@media (max-width:900px) {
  .hero-inner,.contact-grid,.split { grid-template-columns:1fr; }
  .hero { padding:3.5rem 0 3rem; }
  .hero-stats { flex-wrap:wrap; gap:1.5rem; }
  .hero-slider { height:clamp(320px,60vw,450px); }
  .page-head { padding:1.7rem 1.45rem; border-radius:20px; }
  .projects-grid { grid-template-columns:1fr; }
  .project-card:nth-child(n) { grid-column:span 1; }
  .featured-square-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .home-video-frame { min-height: clamp(230px, 52vw, 420px); border-radius: 22px; }
  .home-video-inner iframe { transform: scale(1.28); }
  .services-grid-rich { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .services-cta-band { grid-template-columns:1fr; margin-top:3.4rem; }
  .showcase-grid { grid-template-columns:1fr 1fr; grid-auto-rows:220px; }
  .showcase-grid .showcase-item:nth-child(1),
  .showcase-grid .showcase-item:nth-child(4) { grid-column:span 2; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .project-uniform-grid { grid-template-columns:repeat(2,1fr); }
  .references-grid { grid-template-columns:repeat(2,1fr); }
  .instagram-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .process-highlight-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .process-layout { grid-template-columns:1fr; }
  .process-side-panel { position:static; }
  .cookie-banner-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width:640px) {
  .main-nav { display:none; }
  .nav-burger { display:flex; }
  .page-head { padding:1.35rem 1.1rem; margin-top:.8rem; }
  .page-head::before { right:-170px; top:-180px; }
  .page-head-badge { width:34px; height:34px; border-radius:10px; margin-bottom:.7rem; font-size:.9rem; }
  .footer-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .featured-square-grid { grid-template-columns:1fr; }
  .home-video-band { padding: .65rem 0 .45rem; }
  .home-video-frame { min-height: clamp(210px, 62vw, 320px); border-radius: 18px; }
  .home-video-inner { inset: -14% -20%; }
  .home-video-inner iframe { transform: scale(1.34); }
  .services-grid-rich { grid-template-columns:1fr; }
  .services-cta-band { padding:1.4rem; margin:2.7rem 0 0; }
  .showcase-grid { grid-template-columns:1fr; grid-auto-rows:200px; }
  .showcase-grid .showcase-item:nth-child(n) { grid-column:span 1; }
  .hero-slider { height:350px; }
  .project-uniform-grid { grid-template-columns:1fr; }
  .references-grid { grid-template-columns:1fr; }
  .instagram-grid { grid-template-columns:1fr; }
  .whatsapp-float { right:.85rem; bottom:.85rem; padding:.78rem; }
  .whatsapp-float .wa-text { display:none; }
  .wa-icon { width:26px; height:26px; }
  .slide-content h2 { font-size:1.5rem; }
  .slider-arrow { width:36px; height:36px; font-size:1.1rem; }
  .blog-show-wrap { max-width:min(1000px, 94vw); }
  .blog-cover-media img { height:min(56vw, 420px); }
  .blog-cta-box { grid-template-columns:1fr; text-align:center; }
  .blog-cta-box .btn { width:100%; justify-content:center; }
  .ext-gallery-cta-inner { grid-template-columns:1fr; text-align:center; gap:1.2rem; }
  .ext-gallery-cta-icon { margin:0 auto; }
  .ext-gallery-cta-btn { width:100%; justify-content:center; }
  .ext-gallery-hero { padding:2.2rem 0 2rem; margin-bottom:2rem; }
  .ext-gallery-masonry { columns:2 150px; gap:.4rem; }
  .ext-gallery-item { margin-bottom:.4rem; border-radius:7px; }
  .ext-gallery-skel { border-radius:7px; }
  .ext-gallery-overlay { border-radius:7px; }
  .blog-article-header { text-align:left; }
  .blog-article-meta { justify-content:flex-start; }
  .blog-article-excerpt { margin:0; }
  .process-highlight-grid { grid-template-columns:1fr; }
  .cookie-banner { padding-bottom: calc(env(safe-area-inset-bottom, 0px)); }
  .cookie-banner-actions { width: 100%; }
}

@keyframes spin { to { transform:rotate(360deg); } }
