/*
  SoftMiM — CSS
  Palette (from brief):
  - Accent: #946B2D
  - Dark:   #2E2E2E
  - Light:  #F2F2F2
  - White:  #FFFFFF
  Typography: Roboto (400/600/700)
*/

:root{
  --accent:#946B2D;
  --dark:#2E2E2E;
  --bg:#F2F2F2;
  --white:#FFFFFF;
  --muted:#6E6E6E;
  --radius:22px;
  --radius-lg:28px;
  --shadow:0 18px 40px rgba(0,0,0,.12);
  --shadow-soft:0 10px 26px rgba(0,0,0,.10);
  --container:1180px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Roboto", system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  color:var(--dark);
  background:#D8D8D8;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input{font-family:inherit}

.shell{padding:22px}
.page{
  background:var(--bg);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 18px;
}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(242,242,242,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(46,46,46,.06);
  transition:box-shadow .18s ease, transform .18s ease;
}

/* JS-controlled sticky (robust across overflow/containers) */
.header.is-fixed{
  position:fixed;
  top:var(--header-top, 18px);
  left:var(--header-left, 0px);
  width:var(--header-width, 100%);
  border-radius:18px;
  box-shadow:0 18px 34px rgba(0,0,0,.14);
  border:1px solid rgba(46,46,46,.08);
}

#headerSpacer{height:0}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 0;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-badge{
  width:42px;height:42px;border-radius:14px;
  display:grid;place-items:center;
  background:var(--dark);
  color:var(--white);
  font-weight:700;
  letter-spacing:.4px;
}
.brand-text{display:flex;flex-direction:column;font-weight:700;line-height:1.1}
.brand-text small{font-weight:600;color:rgba(46,46,46,.65);margin-top:2px}

.menu{display:flex;align-items:center;gap:18px}
.menu>a,
.nav-dd{
  font-size:14px;
  font-weight:600;
  color:rgba(46,46,46,.85);
  padding:10px 10px;
  border-radius:12px;
  transition:background .2s ease, color .2s ease;
}
.menu>a:hover,
.nav-dd:hover{background:rgba(148,107,45,.10);color:var(--dark)}

.nav-item{position:relative}
.nav-dd{
  border:0;
  background:transparent;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:8px;
}
.caret{font-size:12px;opacity:.75}

/* Dropdown (fix: hover bridge + pointer-events) */
.dropdown{
  /* bridge: keeps hover when moving from button to menu */

  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:260px;
  background:var(--white);
  border-radius:18px;
  box-shadow:var(--shadow-soft);
  padding:10px;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  z-index:90;
}
.dropdown::before{
  content:"";
  position:absolute;
  left:0;right:0;
  top:-12px;
  height:12px;
}

/* hover bridge: prevents dropdown from disappearing while moving mouse */
.nav-item::after{
  content:"";
  position:absolute;
  left:0;
  top:100%;
  width:100%;
  height:14px;
}

.nav-item:hover .dropdown,
.nav-item:focus-within .dropdown,
.nav-item.is-open .dropdown{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}

.dd-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:11px 12px;
  border-radius:14px;
  font-weight:600;
  color:rgba(46,46,46,.90);
}
.dd-link i{opacity:.72}
.dd-link:hover{background:rgba(46,46,46,.04)}

/* 2nd level dropdown (Proje Listesi alt menü) */
.dd-item{position:relative}
.dd-item.has-sub>.dd-link{padding-right:14px}
.dropdown-sub{
  position:absolute;
  top:0;
  left:calc(100% + 12px);
  min-width:240px;
  background:var(--white);
  border-radius:18px;
  box-shadow:var(--shadow-soft);
  padding:10px;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  z-index:110;
}

/* 2nd level links styling (prevents "iç içe" görünüm) */
.dropdown-sub a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:11px 12px;
  border-radius:14px;
  font-weight:700;
  color:rgba(46,46,46,.90);
}
.dropdown-sub a i{opacity:.72}
.dropdown-sub a:hover{background:rgba(46,46,46,.04)}
.dropdown-sub::before{
  content:"";
  position:absolute;
  left:-12px;
  top:0;bottom:0;
  width:12px;
}

.dd-item.has-sub:hover .dropdown-sub,
.dd-item.has-sub:focus-within .dropdown-sub{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}

.nav-actions{display:flex;align-items:center;gap:10px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(46,46,46,.14);
  background:var(--white);
  color:rgba(46,46,46,.92);
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  transition:transform .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-accent{background:var(--accent);border-color:transparent;color:var(--white)}
.btn-ghost{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.28);color:var(--white)}

.hamburger{
  display:none;
  width:48px;
  height:48px;
  border-radius:16px;
  border:1px solid rgba(46,46,46,.14);
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 20px rgba(0,0,0,.10);
  color:rgba(46,46,46,.92);
  cursor:pointer;
  align-items:center;
  justify-content:center;
}
.hamburger i{font-size:18px}

/* Mobile drawer */
.overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  opacity:0;visibility:hidden;
  transition:opacity .2s ease, visibility .2s ease;
  z-index:90;
}
.drawer{
  position:fixed;
  top:0;right:0;
  height:100vh;
  width:min(360px, 92vw);
  background:var(--white);
  transform:translateX(105%);
  transition:transform .22s ease;
  z-index:100;
  display:flex;
  flex-direction:column;
  padding:14px;
  gap:12px;
}
.drawer-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.drawer-links{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:4px}
.drawer-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 12px;
  border-radius:14px;
  font-weight:700;
  background:rgba(46,46,46,.03);
}
.drawer-link i{opacity:.75}
.drawer-group .drawer-sub{display:none;margin-top:6px;padding-left:10px}
.drawer-group[data-open="true"] .drawer-sub{display:block}
.drawer-sub a{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 10px;
  border-radius:12px;
  font-weight:600;
  color:rgba(46,46,46,.88);
}
.drawer-sub a:hover{background:rgba(46,46,46,.04)}

/* Sub-Sub */
.drawer-nest{margin-bottom:6px}
.drawer-sublink{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 10px;
  border-radius:12px;
  font-weight:700;
  background:rgba(46,46,46,.02);
}
.drawer-nest .drawer-subsub{display:none;padding-left:12px;margin-top:6px}
.drawer-nest[data-open="true"] .drawer-subsub{display:block}
.drawer-subsub a{font-weight:600}

.drawer-cta{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.drawer-cta small{color:rgba(46,46,46,.70)}

body.menu-open .overlay{opacity:1;visibility:visible}
body.menu-open .drawer{transform:translateX(0)}
body.menu-open{overflow:hidden}

/* HERO */
.hero{position:relative;margin-top:18px;margin-bottom:6px}
.hero-slider{
  position:relative;
  border:8px solid rgba(255,255,255,.96);
  border-radius:var(--radius-lg);
  overflow:hidden;
  height:clamp(520px, 52vw, 720px);
   box-sizing:border-box;
  box-shadow:0 18px 45px rgba(0,0,0,.28);
  background:#fff;
}
.hero-slider::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.62) 0%, rgba(0,0,0,.30) 45%, rgba(0,0,0,.08) 72%, rgba(0,0,0,.04) 100%);
  z-index:2;
}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s ease;z-index:1}
.hero-slide.is-active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover}

.hero-content{
  position:absolute;
  left:42px;
  top:50%;
  transform:translateY(-50%);
  max-width:560px;
  color:var(--white);
  z-index:3;
}
.hero-kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.22);
  font-weight:700;
  font-size:13px;
}
.hero-title{
  margin:14px 0 10px;
  font-size:clamp(40px, 5.5vw, 68px);
  line-height:1.02;
  font-weight:800;
  letter-spacing:-0.8px;
}
.hero-sub{
  margin:0 0 16px;
  color:rgba(255,255,255,.86);
  font-weight:500;
  font-size:14px;
  line-height:1.6;
  max-width:520px;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:10px}

/* Controls (arrows left / dots right) */
.hero-controls{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  z-index:4;
}
.hero-arrows{display:flex;gap:10px}
.arrow{
  width:44px;height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(46,46,46,.45);
  color:var(--white);
  display:grid;place-items:center;
  cursor:pointer;
  transition:transform .15s ease, background .15s ease;
}
.arrow:hover{transform:translateY(-1px);background:rgba(46,46,46,.60)}

.hero-dots{
  display:flex;
  align-items:center;
  gap:8px;
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:0;
}
.hero-dot{
  width:10px;height:10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.70);
  background:transparent;
  cursor:pointer;
  opacity:.85;
}
.hero-dot.is-active{background:var(--white);opacity:1}

/* Who card overlay (desktop) */
.hero-who{
  position:absolute;
  right:0;
  bottom:0;
  width:min(390px, 42%);
  background:rgba(242,242,242,.96);
  border-radius:22px;
  padding:16px 16px;
  box-shadow:0 10px 24px rgba(0,0,0,.10);
  border:1px solid rgba(46,46,46,.08);
  z-index:6; /* always over slides */
}
.who-card h3{margin:0 0 6px;font-size:18px}
.who-card p{margin:0 0 12px;color:rgba(46,46,46,.72);font-size:13px;line-height:1.55}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stat{
  background:rgba(255,255,255,.75);
  border:1px solid rgba(46,46,46,.08);
  border-radius:14px;
  padding:10px;
}
.stat strong{display:block;color:var(--accent);font-size:18px;line-height:1.1}
.stat span{display:block;color:rgba(46,46,46,.70);font-size:12px;margin-top:4px}

/* Sections */
.section{padding:34px 0}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:22px;margin-bottom:18px}
.h2{margin:0;font-size:44px;line-height:1.05;letter-spacing:-.6px}
.accent{color:var(--accent)}
.lead{margin:6px 0 0;max-width:520px;color:rgba(46,46,46,.72);font-weight:500;line-height:1.6}
.center{text-align:center}

/* Match */
.match{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:stretch}
.card{background:var(--white);border-radius:22px;box-shadow:0 10px 24px rgba(0,0,0,.08);overflow:hidden;position:relative}
.match-left{min-height:420px;aspect-ratio:1/1}
.match-left img{width:100%;height:100%;object-fit:cover}
.info-pill{
  position:absolute;
  left:16px;right:16px;bottom:16px;
  background:rgba(242,242,242,.92);
  border:1px solid rgba(46,46,46,.10);
  border-radius:18px;
  padding:14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.price{font-weight:800;color:var(--accent);font-size:20px}
.meta{margin:6px 0 0;color:rgba(46,46,46,.72);font-size:12px;line-height:1.5}
.pill-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;min-width:220px}
.mini{background:rgba(255,255,255,.75);border:1px solid rgba(46,46,46,.08);border-radius:14px;padding:10px;text-align:center}
.mini b{display:block;font-size:13px}
.mini small{display:block;color:rgba(46,46,46,.65);margin-top:2px}

.match-right{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.tile{
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  background:var(--white);
  aspect-ratio:1/1;
}
.tile img{width:100%;height:100%;object-fit:cover}

/* About */
.about{display:grid;grid-template-columns:1fr 1.2fr;gap:18px;align-items:stretch}
.about-dark{
  background:var(--dark);
  color:var(--white);
  border-radius:22px;
  padding:22px;
}
.about-dark h3{margin:0 0 10px;font-size:28px}
.about-dark p{margin:0 0 12px;color:rgba(255,255,255,.80);line-height:1.6;font-size:13px}
.about-bullets{margin:14px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.about-bullets li{display:flex;align-items:flex-start;gap:10px;color:rgba(255,255,255,.86);font-weight:600}
.about-bullets i{color:var(--accent);margin-top:2px}
.about-media{border-radius:22px;overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.08)}
.about-media img{width:100%;height:100%;object-fit:cover}

/* Filters + Rail */
.filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:16px}
.chip{
  border:1px solid rgba(46,46,46,.14);
  background:var(--white);
  border-radius:999px;
  padding:10px 14px;
  font-weight:800;
  font-size:12px;
  cursor:pointer;
}
.chip.active{background:var(--accent);border-color:transparent;color:var(--white)}
.search{
  display:flex;align-items:center;gap:10px;
  background:var(--white);
  border:1px solid rgba(46,46,46,.14);
  border-radius:999px;
  padding:10px 14px;
}
.search input{border:0;outline:0;background:transparent;min-width:min(360px, 70vw)}

.rail-wrap{position:relative;margin-top:16px}
.rail{display:flex;gap:14px;overflow:auto;scroll-snap-type:x mandatory;padding:6px 4px 16px;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.rail-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:999px;
  border:1px solid rgba(46,46,46,.14);
  background:var(--white);
  box-shadow:0 10px 22px rgba(0,0,0,.08);
  cursor:pointer;
}
.rail-prev{left:-8px}
.rail-next{right:-8px}

.proj{
  min-width:320px;
  scroll-snap-align:start;
  border-radius:22px;
  overflow:hidden;
  background:var(--white);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}
.proj img{width:100%;height:210px;object-fit:cover}
.proj-info{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px}
.proj-info h4{margin:0 0 6px;font-size:16px}
.proj-info p{margin:0;color:rgba(46,46,46,.70);font-size:12px;line-height:1.55}
.tag{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:rgba(148,107,45,.10);color:var(--accent);font-weight:800;font-size:12px;white-space:nowrap}

/* Testimonials */
.testi-card{
  position:relative;
  background:var(--white);
  border-radius:22px;
  padding:26px 18px;
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  max-width:760px;
  margin:18px auto 0;
  text-align:center;
}
.stars{display:flex;gap:6px;justify-content:center;color:var(--accent);margin-bottom:10px}
.quote{margin:0 auto 16px;max-width:620px;font-size:14px;line-height:1.7;color:rgba(46,46,46,.78);font-weight:600}
.who{display:flex;gap:10px;justify-content:center;align-items:center}
.avatar{width:44px;height:44px;border-radius:999px;overflow:hidden;border:2px solid rgba(148,107,45,.35)}
.avatar img{width:100%;height:100%;object-fit:cover}
.who b{display:block}
.who span{display:block;color:rgba(46,46,46,.65);font-size:12px;margin-top:2px}
.t-nav{
  position:absolute;
  top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:999px;
  border:1px solid rgba(46,46,46,.14);
  background:var(--white);
  box-shadow:0 10px 22px rgba(0,0,0,.08);
  cursor:pointer;
}
.t-prev{left:12px}
.t-next{right:12px}

/* Footer */
.footer{
  background:#202020;
  color:var(--white);
  border-radius:22px;
  padding:24px 18px;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:18px}
.footer h4{margin:0 0 12px}
.footer p{margin:0 0 14px;color:rgba(255,255,255,.75);line-height:1.6;font-size:13px}
.footer-cols{display:grid;gap:10px}
.footer-cols a{color:rgba(255,255,255,.78);font-weight:600}
.footer-cols a:hover{color:var(--white)}
.newsletter{display:flex;gap:10px;align-items:center;margin:12px 0}
.newsletter input{
  flex:1;
  border:0;
  outline:0;
  border-radius:999px;
  padding:12px 14px;
  background:rgba(255,255,255,.10);
  color:var(--white);
}
.newsletter input::placeholder{color:rgba(255,255,255,.55)}
.newsletter button{
  border:0;
  background:var(--accent);
  color:var(--white);
  font-weight:800;
  border-radius:999px;
  padding:12px 16px;
  cursor:pointer;
}
.social{display:flex;gap:10px;margin-top:10px}
.social a{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14)}
.social a:hover{background:rgba(255,255,255,.16)}

.foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.70);font-weight:600;font-size:12px}

/* Floating quick actions */
.quick-actions{
  position:fixed;
  right:18px;
  bottom:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:70;
  transition:opacity .18s ease, transform .18s ease;
}
.qbtn{
  width:44px;height:44px;
  border-radius:14px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(46,46,46,.12);
  box-shadow:0 10px 20px rgba(0,0,0,.12);
  cursor:pointer;
}
.qbtn i{color:inherit}
.qbtn.accent{background:var(--accent);border-color:transparent;color:var(--white)}
.qbtn.dark{background:var(--dark);border-color:transparent;color:var(--white)}
.qbtn.hidden{display:none}

/* When mobile menu is open, keep floating buttons under the drawer */
body.menu-open .quick-actions{opacity:0;pointer-events:none;transform:translateY(8px)}

/* Responsive */
@media (max-width: 980px){
  .menu{display:none}
  .hamburger{display:inline-flex}
  .btn-call,.btn-offer{display:none}
  .hero-content{left:20px;right:20px;max-width:none}
  .hero-title{font-size:clamp(34px, 9vw, 50px)}
  .hero-controls{left:14px;right:14px}
  .section-head{flex-direction:column}
  .h2{font-size:36px}
  .match{grid-template-columns:1fr;}
  .match-left{min-height:360px}
  .pill-grid{min-width:0}
  .about{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}

@media (max-width: 740px){
  /* Prevent pill-grid from being clipped on narrow screens */
  .info-pill{flex-direction:column;align-items:stretch}
  .pill-grid{width:100%;grid-template-columns:repeat(3, minmax(0,1fr))}
  .mini{padding:10px 8px}
}

@media (max-width: 820px){
  /* Stat card below slider on mobile */
  .hero{padding-bottom:0}
  .hero-who{position:static;width:100%;margin-top:14px}
  .hero-slider{height:520px}
}

@media (max-width: 520px){
  .shell{padding:12px}
  .hero-slider{height:480px}
  .hero-kicker{font-size:12px}
  .hero-sub{font-size:13px}
  .stats{grid-template-columns:1fr;}
}


/* ================= Theme Variables + Desktop Appearance Panel ================= */
:root{
  /* Theme mapping (used by Görünüm Ayarları panel) */
  --primary: var(--accent);
  --secondary: var(--dark);
  --gold: var(--accent);

  --text: var(--dark);
  --mutedText: var(--muted);

  --body-bg:#D8D8D8;
  --page-bg: var(--bg);
  --card-bg: var(--white);

  --sand:#E7D7BE;
  --line:#E2E2E2;
}

/* Keep existing look as default; allow runtime overrides via CSS variables */
body{background:var(--body-bg); color:var(--text)}
.page{background:var(--page-bg)}
.btn-accent{background:var(--primary)}
.accent{color:var(--primary)}
.brand-badge{background:var(--secondary)}
.stars{color:var(--gold)}
.lead{color:var(--mutedText)}
.meta{color:var(--mutedText)}
.proj-info p{color:var(--mutedText)}
.who-card p{color:var(--mutedText)}

/* Themed module overrides only when user applied settings */
@media (min-width: 981px){
  [data-module][data-themed="1"]{
    background:var(--m-bg, transparent);
    color:var(--m-text, inherit);
  }
  [data-module][data-themed="1"] .lead,
  [data-module][data-themed="1"] p,
  [data-module][data-themed="1"] .proj-info p,
  [data-module][data-themed="1"] .meta,
  [data-module][data-themed="1"] .who-card p{
    color:var(--m-muted, currentColor);
  }

  /* Header needs special handling for readability */
  header.header[data-themed="1"]{
    background:var(--m-bg, rgba(242,242,242,.92));
    border-bottom:1px solid color-mix(in srgb, var(--m-text) 10%, transparent);
  }

  /* Module shadow toggle (desktop only) */
  body.module-shadow-on .section{
    background:color-mix(in srgb, var(--card-bg) 86%, transparent);
    border:1px solid color-mix(in srgb, var(--line) 70%, transparent);
    border-radius:var(--radius-lg);
    box-shadow:0 12px 26px rgba(0,0,0,.08);
    padding:28px 0;
    margin:18px 0;
  }
  body.module-shadow-on .section:first-of-type{margin-top:10px}
}

/* Match module: left visual height aligns with right tiles on desktop */
@media (min-width: 981px){
  .match{align-items:stretch}
  .match-left{
    aspect-ratio:auto;
    min-height:0;
    height:100%;
  }
  .match-left img{height:100%}
}

/* ---------- Theme panel UI (Desktop only) ---------- */
@media (max-width: 980px){
  .theme-fab,.theme-overlay,.theme-panel{display:none !important}
}

@media (min-width: 981px){
  .theme-fab{
    position:fixed;
    left:18px;
    bottom:18px;
    width:48px;
    height:48px;
    border-radius:16px;
    border:1px solid rgba(46,46,46,.12);
    background:rgba(255,255,255,.92);
    box-shadow:0 10px 22px rgba(0,0,0,.12);
    z-index:120;
    cursor:pointer;
    display:grid;
    place-items:center;
    color:rgba(46,46,46,.92);
  }
  .theme-fab i{font-size:18px}

  .theme-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.35);
    opacity:0;
    visibility:hidden;
    transition:opacity .18s ease, visibility .18s ease;
    z-index:119;
  }

  .theme-panel{
    position:fixed;
    left:18px;
    top:18px;
    height:calc(100vh - 36px);
    width:360px;
    background:var(--card-bg);
    border:1px solid rgba(46,46,46,.10);
    border-radius:22px;
    box-shadow:0 22px 60px rgba(0,0,0,.20);
    z-index:121;
    display:flex;
    flex-direction:column;
    overflow:hidden;
    transform:translateX(-110%);
    transition:transform .22s ease;
  }

  body.theme-open .theme-overlay{opacity:1;visibility:visible}
  body.theme-open .theme-panel{transform:translateX(0)}

  .theme-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    padding:16px 16px 10px;
    border-bottom:1px solid rgba(46,46,46,.08);
  }
  .theme-head b{display:block;font-size:16px}
  .theme-head small{display:block;color:rgba(46,46,46,.62);margin-top:3px;font-weight:600}
  .theme-close{
    width:40px;height:40px;border-radius:14px;
    border:1px solid rgba(46,46,46,.12);
    background:rgba(46,46,46,.03);
    cursor:pointer;
    display:grid;place-items:center;
  }

  .theme-tabs{
    padding:12px 14px;
    display:flex;
    gap:10px;
    flex-wrap:wrap;
  }
  .ttab{
    border:1px solid rgba(46,46,46,.14);
    background:transparent;
    border-radius:999px;
    padding:10px 12px;
    font-weight:800;
    font-size:12px;
    cursor:pointer;
    transition:background .15s ease, color .15s ease, border-color .15s ease;
  }
  .ttab.is-active{
    background:var(--secondary);
    color:var(--card-bg);
    border-color:transparent;
  }

  .theme-body{
    padding:6px 14px 14px;
    overflow:auto;
  }
  .theme-body.hidden{display:none}

  .trow{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:12px 0;
    border-bottom:1px dashed rgba(46,46,46,.10);
  }
  .trow b{display:block;font-size:13px}
  .trow small{display:block;color:rgba(46,46,46,.60);margin-top:3px;font-weight:600;max-width:220px}
  .tcolor{
    width:44px;height:34px;
    border:1px solid rgba(46,46,46,.16);
    border-radius:10px;
    background:transparent;
    padding:0;
    cursor:pointer;
  }
  .tselect{
    min-width:190px;
    border:1px solid rgba(46,46,46,.14);
    border-radius:14px;
    padding:10px 12px;
    font-weight:700;
    background:var(--card-bg);
  }

  .tswitch{
    position:relative;
    width:52px;height:30px;
    border-radius:999px;
    border:1px solid rgba(46,46,46,.14);
    background:rgba(46,46,46,.06);
    display:inline-flex;
    align-items:center;
    padding:3px;
  }
  .tswitch input{position:absolute;opacity:0;pointer-events:none}
  .tswitch .track{
    width:24px;height:24px;
    border-radius:999px;
    background:var(--card-bg);
    box-shadow:0 8px 16px rgba(0,0,0,.12);
    transform:translateX(0);
    transition:transform .18s ease, background .18s ease;
  }
  .tswitch input:checked + .track{
    transform:translateX(22px);
    background:var(--primary);
  }

  .tlist{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin-top:10px;
  }
  .titem{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:12px 12px;
    border-radius:18px;
    border:1px solid rgba(46,46,46,.10);
    background:rgba(46,46,46,.02);
  }
  .titem b{font-size:13px}
  .titem small{display:block;color:rgba(46,46,46,.60);font-weight:700;margin-top:2px}
  .titem button{
    border:1px solid rgba(46,46,46,.14);
    background:color-mix(in srgb, var(--sand) 65%, white);
    border-radius:14px;
    padding:10px 12px;
    font-weight:900;
    cursor:pointer;
  }

  .tchip{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    padding:8px 10px;
    background:rgba(46,46,46,.04);
    border:1px solid rgba(46,46,46,.10);
    font-weight:900;
    font-size:12px;
  }

  .tapply{
    width:100%;
    margin-top:12px;
    border:1px solid rgba(46,46,46,.14);
    background:color-mix(in srgb, var(--sand) 60%, white);
    border-radius:16px;
    padding:12px 14px;
    font-weight:900;
    cursor:pointer;
  }

  .theme-foot{
    margin-top:auto;
    display:flex;
    gap:12px;
    padding:14px;
    border-top:1px solid rgba(46,46,46,.08);
    background:color-mix(in srgb, var(--page-bg) 55%, white);
  }
  .tbtn{
    flex:1;
    border-radius:18px;
    padding:12px 14px;
    font-weight:900;
    cursor:pointer;
    border:1px solid rgba(46,46,46,.14);
    background:var(--card-bg);
  }
  .tbtn.primary{background:var(--secondary);color:var(--card-bg);border-color:transparent}
  .tbtn.ghost{background:transparent}

  .theme-note{
    padding:12px 14px 14px;
    color:rgba(46,46,46,.62);
    font-weight:700;
    font-size:12px;
    border-top:1px dashed rgba(46,46,46,.10);
  }
}

/* ---------- Photo gallery ---------- */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
}
.photo-item{
  border-radius:22px;
  overflow:hidden;
  background:var(--card-bg);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  border:1px solid rgba(46,46,46,.06);
  cursor:pointer;
}
.photo-item img{width:100%;height:170px;object-fit:cover;transition:transform .18s ease}
.photo-item:hover img{transform:scale(1.02)}

@media (max-width: 980px){
  .photo-grid{grid-template-columns:repeat(2, 1fr)}
  .photo-item img{height:160px}
}

/* ---------- Video gallery ---------- */
.video-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.video-card{
  background:var(--card-bg);
  border-radius:22px;
  border:1px solid rgba(46,46,46,.06);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  overflow:hidden;
  cursor:pointer;
}
.video-thumb{position:relative}
.video-thumb img{width:100%;height:210px;object-fit:cover}
.video-badge{
  position:absolute;
  left:12px;
  bottom:12px;
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(46,46,46,.12);
  font-weight:900;
}
.video-info{padding:14px}
.video-info h4{margin:0 0 6px;font-size:16px}
.video-info p{margin:0;color:var(--mutedText);font-size:12px;line-height:1.55}

@media (max-width: 980px){
  .video-grid{grid-template-columns:1fr}
}

/* ---------- Blog module ---------- */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.blog-card{
  background:var(--card-bg);
  border-radius:22px;
  border:1px solid rgba(46,46,46,.06);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .15s ease;
}
.blog-card:hover{transform:translateY(-2px)}
.blog-media img{width:100%;height:190px;object-fit:cover}
.blog-body{padding:14px}
.blog-meta{display:inline-flex;gap:8px;align-items:center;color:rgba(46,46,46,.62);font-weight:800;font-size:12px}
.blog-body h4{margin:8px 0 8px;font-size:16px}
.blog-body p{margin:0 0 10px;color:var(--mutedText);font-size:12px;line-height:1.6}
.blog-more{display:inline-flex;gap:8px;align-items:center;font-weight:900;color:var(--primary);font-size:12px}

@media (max-width: 980px){
  .blog-grid{grid-template-columns:1fr}
}

/* ---------- Lightbox (Photo/Video fixed frame) ---------- */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.62);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:130;
  padding:22px;
}
.lightbox.is-open{display:flex}
.lightbox-card{
  position:relative;
  width:min(980px, 92vw);
  height:min(620px, 84vh);
  background:var(--card-bg);
  border-radius:22px;
  border:1px solid rgba(255,255,255,.18);
  overflow:hidden;
  box-shadow:0 26px 80px rgba(0,0,0,.40);
}
.lightbox-card img{
  width:100%;
  height:100%;
  object-fit:contain;
  background:#111;
}
.lightbox-card.video{
  background:#111;
}
.lightbox-card.video video{
  width:100%;
  height:100%;
  object-fit:contain;
  background:#111;
}
.lightbox-close{
  position:absolute;
  right:14px;
  top:14px;
  width:42px;height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(0,0,0,.40);
  color:#fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  z-index:2;
}

/* =========================================================
   HERO tweaks (All devices)
   - White frame around slider image
   - Slightly reduced slider height (short & wide look)
========================================================= */
.hero{margin-top:12px}
.hero-slider{
  /* White frame */
  border:8px solid rgba(255,255,255,.96);
  /* keep rounded corners with border */
  border-radius:var(--radius-lg);
  /* shorter (compared to default), but still readable */
  height:clamp(420px, 38vw, 560px);
  box-sizing:border-box;
}

.hero-slide video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}


/* Ana Sayfa Hizmetlerimiz */
.home-services{
    position:relative;
}

.home-service-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
}

.home-service-card{
    position:relative;
    display:block;
    min-height:360px;
    overflow:hidden;
    border-radius:var(--radius);
    background:#fff;
    border:1px solid var(--line);
    text-decoration:none !important;
    color:var(--text);
    box-shadow:0 20px 50px rgba(0,0,0,.07);
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.home-service-card:hover{
    transform:translateY(-5px);
    box-shadow:0 26px 70px rgba(0,0,0,.12);
    border-color:rgba(148,107,45,.28);
}

.home-service-media{
    height:180px;
    overflow:hidden;
    background:#f3f3f3;
}

.home-service-media img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .35s ease;
}

.home-service-card:hover .home-service-media img{
    transform:scale(1.06);
}

.home-service-icon{
    position:absolute;
    top:148px;
    left:22px;
    z-index:2;
    width:58px;
    height:58px;
    border-radius:18px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:var(--gold);
    color:#fff;
    box-shadow:0 16px 35px rgba(0,0,0,.18);
    border:4px solid #fff;
}

.home-service-icon i{
    font-size:22px;
}

.home-service-body{
    padding:40px 22px 22px;
}

.home-service-body h3{
    margin:0 0 10px;
    font-size:21px;
    letter-spacing:-.3px;
}

.home-service-body p{
    margin:0 0 18px;
    color:var(--muted);
    line-height:1.65;
    font-size:14px;
}

.home-service-body span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:var(--gold);
    font-weight:800;
    font-size:14px;
}

.home-services-more{
    display:flex;
    justify-content:center;
    margin-top:24px;
}

@media(max-width:980px){
    .home-service-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media(max-width:640px){
    .home-service-grid{
        grid-template-columns:1fr;
    }

    .home-service-card{
        min-height:auto;
    }
}


/* Ana Sayfa - Proje Vitrini Üstü Hizmetlerimiz */
.home-services{
    position:relative;
}

.home-service-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:18px;
}

.home-service-card{
    position:relative;
    display:block;
    min-height:360px;
    overflow:hidden;
    border-radius:var(--radius);
    background:#fff;
    border:1px solid var(--line);
    text-decoration:none !important;
    color:var(--text);
    box-shadow:0 20px 50px rgba(0,0,0,.07);
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.home-service-card:hover{
    transform:translateY(-5px);
    box-shadow:0 26px 70px rgba(0,0,0,.12);
    border-color:rgba(148,107,45,.28);
}

.home-service-media{
    height:180px;
    overflow:hidden;
    background:#f3f3f3;
}

.home-service-media img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .35s ease;
}

.home-service-card:hover .home-service-media img{
    transform:scale(1.06);
}

.home-service-icon{
    position:absolute;
    top:148px;
    left:22px;
    z-index:2;
    width:58px;
    height:58px;
    border-radius:18px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:var(--gold);
    color:#fff;
    box-shadow:0 16px 35px rgba(0,0,0,.18);
    border:4px solid #fff;
}

.home-service-icon i{
    font-size:22px;
}

.home-service-body{
    padding:40px 22px 22px;
}

.home-service-body h3{
    margin:0 0 10px;
    font-size:21px;
    letter-spacing:-.3px;
}

.home-service-body p{
    margin:0 0 18px;
    color:var(--muted);
    line-height:1.65;
    font-size:14px;
}

.home-service-body span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:var(--gold);
    font-weight:800;
    font-size:14px;
}

.home-services-more{
    display:flex;
    justify-content:center;
    margin-top:24px;
}

@media(max-width:980px){
    .home-service-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media(max-width:640px){
    .home-service-grid{grid-template-columns:1fr;}
    .home-service-card{min-height:auto;}
}
