/* ============================================================
   FTM TEKNİK — Tasarım Sistemi v3.0 (SEO + Endüstriyel)
   Dark Tech Industrial — Electric Blue + Burn Orange
   © 2026 FTM Teknik
============================================================ */
:root {
  --bg0:       #03080f;
  --bg1:       #060d1a;
  --bg2:       #091526;
  --bg3:       #0c1d34;
  --blue:      #0066ff;
  --blue-b:    #0044cc;
  --blue-l:    #3388ff;
  --blue-g:    rgba(0,102,255,.22);
  --orange:    #ff4400;
  --orange-l:  #ff6633;
  --green:     #00cc6a;
  --gold:      #ffcc00;
  --white:     #ddeeff;
  --gray:      #5a7090;
  --gray-l:    #8aa8c8;
  --card:      rgba(9,21,38,.88);
  --border:    rgba(0,102,255,.14);
  --border-h:  rgba(0,102,255,.45);
  --glow:      0 0 40px rgba(0,102,255,.3);
  --glow-o:    0 0 30px rgba(255,68,0,.25);
  --shadow:    0 24px 80px rgba(0,0,0,.6);
  --font-h:    'Exo 2', sans-serif;
  --font-b:    'Nunito', sans-serif;
  --font-m:    'Space Mono', monospace;
  --tr:        .3s cubic-bezier(.4,0,.2,1);
  --tr-s:      .5s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; overflow-x:hidden }
body { background:var(--bg0); color:var(--white); font-family:var(--font-b); line-height:1.65; overflow-x:hidden }
a { text-decoration:none; color:inherit }
img { max-width:100%; display:block }
button { font-family:var(--font-b); cursor:pointer }
::selection { background:var(--blue); color:#fff }

#sprg { position:fixed; top:0; left:0; height:3px; z-index:9999; width:0;
  background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue));
  background-size:200% 100%; animation:gradmove 3s linear infinite; transition:width .08s linear }
@keyframes gradmove { 0%{background-position:0% 50%} 100%{background-position:200% 50%} }

.toast { position:fixed; top:82px; right:20px; z-index:9990; padding:14px 22px;
  border-radius:10px; font-weight:700; font-size:.87rem; font-family:var(--font-h);
  transform:translateX(130%); transition:all .4s cubic-bezier(.34,1.56,.64,1);
  max-width:320px; box-shadow:var(--shadow); pointer-events:none; letter-spacing:.3px }
.toast.show { transform:translateX(0) }
.toast.err { background:rgba(255,50,50,.1); border:1px solid rgba(255,80,80,.3); color:#ff9999 }
.toast.ok  { background:rgba(0,204,102,.1); border:1px solid rgba(0,204,102,.28); color:#00dd88 }
.toast.inf { background:rgba(0,102,255,.1); border:1px solid rgba(0,102,255,.28); color:var(--blue-l) }

.ldov { display:none; position:fixed; inset:0; background:rgba(3,8,15,.88);
  backdrop-filter:blur(16px); z-index:9980; align-items:center; justify-content:center;
  flex-direction:column; gap:18px }
.ldov.on { display:flex }
.spin { width:52px; height:52px; border:3px solid rgba(0,102,255,.15);
  border-top-color:var(--blue); border-radius:50%; animation:spin 1s linear infinite }
@keyframes spin { to { transform:rotate(360deg) } }
.ldtxt { font-family:var(--font-h); font-weight:700; font-size:.9rem; color:var(--gray-l); letter-spacing:1px }

#pcanvas { position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.35 }

nav { position:fixed; top:0; left:0; right:0; z-index:1000; height:72px;
  display:flex; align-items:center; justify-content:space-between; padding:0 5%;
  transition:all var(--tr-s) }
nav.sc { background:rgba(3,8,15,.95); backdrop-filter:blur(28px);
  border-bottom:1px solid var(--border); height:62px; box-shadow:0 4px 40px rgba(0,0,0,.5) }
.nlogo { display:flex; align-items:center; gap:12px; z-index:10 }
.nlogo-txt { display:flex; flex-direction:column; line-height:1 }
.nlogo-ftm { font-family:var(--font-h); font-size:1.6rem; font-weight:900; color:var(--white); letter-spacing:3px }
.nlogo-sub { font-family:var(--font-m); font-size:.5rem; color:var(--blue-l); letter-spacing:5px; text-transform:uppercase }
.nlinks { display:flex; gap:24px; list-style:none; align-items:center }
.nlinks a { color:var(--gray-l); font-size:.85rem; font-weight:700; letter-spacing:.4px; transition:color var(--tr); position:relative; padding:4px 0 }
.nlinks a::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px; background:linear-gradient(90deg,var(--blue),var(--orange)); transition:width var(--tr) }
.nlinks a:hover { color:var(--white) }
.nlinks a:hover::after { width:100% }
.ncta { background:var(--blue) !important; color:#fff !important; padding:10px 20px; border-radius:7px; box-shadow:0 0 22px var(--blue-g) }
.ncta::after { display:none !important }
.ncta:hover { background:var(--blue-l) !important; transform:translateY(-2px) }
.hbg { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px; cursor:pointer; z-index:1010 }
.hbg span { display:block; width:25px; height:2px; background:var(--white); transition:all var(--tr); border-radius:2px }
.hbg.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.hbg.open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.hbg.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }
.mnav-backdrop { display:none; position:fixed; inset:0; top:62px; z-index:10040;
  background:rgba(0,0,0,.55); -webkit-tap-highlight-color:transparent }
.mnav-backdrop.open { display:block }
.mnav { display:none; position:fixed; left:0; right:0; bottom:0; top:62px; background:rgba(3,8,15,.98);
  backdrop-filter:blur(30px); flex-direction:column; padding:28px 8% 48px; gap:4px;
  border-top:1px solid var(--border); z-index:10050; animation:mopen .3s ease both;
  overflow-y:auto; -webkit-overflow-scrolling:touch; pointer-events:auto }
.mnav.open { display:flex }
body.menu-open { overflow:hidden; touch-action:none }
@keyframes mopen { from{opacity:0;transform:translateY(-10px)} to{opacity:1;transform:translateY(0)} }
.mnav a { display:block; font-family:var(--font-h); font-size:1.15rem; font-weight:700; color:var(--gray-l);
  border-bottom:1px solid var(--border); padding:18px 4px; min-height:52px; line-height:1.3;
  transition:color var(--tr); -webkit-tap-highlight-color:transparent; touch-action:manipulation }
.mnav a:hover, .mnav a:active { color:var(--white) }
.mnav .ncta { margin-top:12px; text-align:center; border:none !important; padding:16px !important }
.trust-strip { margin-top:20px }
.trust-google { color:var(--blue-l); font-size:.92rem; font-weight:700; text-decoration:underline; text-underline-offset:3px }
.trust-google:hover { color:var(--white) }

/* BREADCRUMB */
.bcrumb { background:var(--bg1); padding:78px 5% 18px; font-size:.83rem; color:var(--gray-l); border-bottom:1px solid var(--border) }
.bcrumb ol { display:flex; flex-wrap:wrap; gap:8px; list-style:none; max-width:1200px; margin:0 auto; align-items:center }
.bcrumb li { display:flex; align-items:center; gap:8px }
.bcrumb li::after { content:'›'; color:var(--gray); margin-left:8px }
.bcrumb li:last-child::after { display:none }
.bcrumb a { color:var(--blue-l); font-weight:700 }
.bcrumb a:hover { color:var(--white) }
.bcrumb li:last-child span { color:var(--white); font-weight:700 }

section { padding:96px 5%; position:relative; z-index:2 }
.sh { text-align:center; margin-bottom:64px }
.stag { display:inline-flex; align-items:center; gap:8px; color:var(--blue-l);
  font-family:var(--font-m); font-size:.72rem; font-weight:700; letter-spacing:4px; text-transform:uppercase; margin-bottom:14px }
.stag::before,.stag::after { content:'—'; color:var(--blue); opacity:.5 }
.stitle { font-family:var(--font-h); font-size:clamp(1.9rem,3.5vw,2.9rem); font-weight:900; line-height:1.15; margin-bottom:16px }
.stitle em { color:var(--blue); font-style:normal }
.stitle strong { color:var(--orange); font-weight:900 }
.sdesc { color:var(--gray-l); font-size:1rem; max-width:620px; margin:0 auto; line-height:1.85 }

.rev { opacity:0; transform:translateY(36px); transition:opacity .75s ease, transform .75s ease }
.rev.vis { opacity:1; transform:translateY(0) }
.rev.left { transform:translateX(-36px) }
.rev.left.vis { transform:translateX(0) }
.rev.right { transform:translateX(36px) }
.rev.right.vis { transform:translateX(0) }
.rev.scale { transform:scale(.88) }
.rev.scale.vis { transform:scale(1) }

.btn { display:inline-flex; align-items:center; gap:10px; border:none; border-radius:9px;
  font-family:var(--font-h); font-weight:700; font-size:.97rem; letter-spacing:.4px; transition:all var(--tr); cursor:pointer }
.btn-primary { background:var(--blue); color:#fff; padding:17px 38px;
  box-shadow:0 0 40px var(--blue-g); font-size:1.05rem }
.btn-primary:hover { background:var(--blue-l); transform:translateY(-3px); box-shadow:0 14px 55px var(--blue-g) }
.btn-secondary { background:transparent; color:var(--white); padding:15px 28px;
  border:2px solid var(--border); font-size:.95rem }
.btn-secondary:hover { border-color:var(--blue); color:var(--blue-l); background:rgba(0,102,255,.06); transform:translateY(-2px) }
.btn-wa { background:#25d366; color:#fff; padding:15px 28px; box-shadow:0 0 30px rgba(37,211,102,.25) }
.btn-wa:hover { background:#1fb855; transform:translateY(-3px) }
.btn-ph { background:transparent; color:var(--white); padding:14px 26px; border:2px solid var(--border) }
.btn-ph:hover { border-color:var(--blue); color:var(--blue-l); background:rgba(0,102,255,.06); transform:translateY(-2px) }
.btn-outline { background:transparent; color:var(--blue-l); padding:12px 24px; border:2px solid var(--border); font-size:.88rem }
.btn-outline:hover { border-color:var(--blue-l); background:rgba(0,102,255,.06) }
.btn-orange { background:var(--orange); color:#fff; padding:15px 30px; box-shadow:0 0 30px rgba(255,68,0,.25) }
.btn-orange:hover { background:var(--orange-l); transform:translateY(-2px) }

#hero { min-height:100vh; position:relative; display:flex; align-items:center; padding:110px 5% 70px; overflow:hidden; z-index:1 }
.hero-bg { position:absolute; inset:0; z-index:0;
  background:radial-gradient(ellipse 80% 70% at 65% 50%, rgba(0,60,180,.12) 0%, transparent 65%),
             radial-gradient(ellipse 50% 45% at 10% 85%, rgba(255,68,0,.07) 0%, transparent 55%),
             linear-gradient(175deg,#03080f 0%,#060d1a 100%) }
.hero-grid { position:absolute; inset:0; z-index:0;
  background-image:linear-gradient(rgba(0,102,255,.04) 1px, transparent 1px),
                   linear-gradient(90deg, rgba(0,102,255,.04) 1px, transparent 1px);
  background-size:60px 60px; animation:gridmove 30s linear infinite }
@keyframes gridmove { 0%{transform:translateY(0)} 100%{transform:translateY(60px)} }
.hero-scan { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none }
.hero-scan::after { content:''; position:absolute; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,rgba(0,102,255,.6),transparent);
  animation:scan 6s linear infinite; top:-2px }
@keyframes scan { 0%{top:-2px} 100%{top:100%} }

.hero-content { position:relative; z-index:2; max-width:680px }
.hbadge { display:inline-flex; align-items:center; gap:10px;
  background:rgba(0,102,255,.1); border:1px solid rgba(0,102,255,.25);
  border-radius:50px; padding:9px 22px; font-family:var(--font-m);
  font-size:.72rem; color:var(--blue-l); letter-spacing:2px; margin-bottom:28px }
.hbadge .dot { width:8px; height:8px; border-radius:50%; background:var(--blue); animation:pulse 2s infinite; flex-shrink:0 }
@keyframes pulse { 0%,100%{opacity:1;box-shadow:0 0 0 0 var(--blue-g)} 50%{opacity:.5;box-shadow:0 0 0 8px transparent} }
.htitle { font-family:var(--font-h); font-size:clamp(2.3rem,5vw,4.3rem); font-weight:900; line-height:1.06; margin-bottom:24px; text-shadow:0 2px 40px rgba(0,102,255,.15) }
.htitle .line1 { color:var(--white) }
.htitle .line2 { color:var(--blue); display:block }
.htitle .line3 { color:var(--orange); display:block; font-style:italic }
.hdesc { font-size:1.05rem; color:var(--gray-l); margin-bottom:30px; line-height:1.85 }
.hdesc strong { color:var(--white) }

.hbtns { display:flex; gap:14px; flex-wrap:wrap; align-items:center }
.hbtns .btn-primary { flex-shrink:0 }
.hbtns .btn-secondary { flex-shrink:0 }
.wa-icon-btn { width:52px; height:52px; border-radius:50%; background:#25d366; display:flex;
  align-items:center; justify-content:center; transition:all var(--tr); flex-shrink:0;
  box-shadow:0 0 24px rgba(37,211,102,.3) }
.wa-icon-btn:hover { background:#1fb855; transform:scale(1.1) }

.price-note { display:inline-flex; align-items:center; gap:9px;
  background:rgba(255,204,0,.07); border:1px solid rgba(255,204,0,.2);
  border-radius:8px; padding:10px 18px; font-size:.82rem; font-weight:700;
  color:rgba(255,204,0,.85); margin-top:22px; font-family:var(--font-h) }

.hero-badges { display:flex; flex-wrap:wrap; gap:10px; margin-top:28px }
.hbadge-sm { display:inline-flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:50px; padding:7px 16px; font-size:.77rem; font-weight:700;
  color:var(--gray-l); font-family:var(--font-h) }

.hero-visual { position:absolute; right:4%; top:50%; transform:translateY(-50%);
  z-index:2; width:420px; animation:hvisual 1.4s cubic-bezier(.34,1.2,.64,1) .3s both }
@keyframes hvisual { from{opacity:0;transform:translateY(-45%) translateX(40px)} to{opacity:1;transform:translateY(-50%) translateX(0)} }

.rating-strip { display:flex; align-items:center; gap:14px; margin-top:20px; flex-wrap:wrap }
.stars { display:flex; gap:3px }
.star { color:var(--gold); font-size:1.1rem }
.rating-text { font-size:.82rem; color:var(--gray-l); font-family:var(--font-h); font-weight:700 }
.rating-text strong { color:var(--white) }

.statsbar { background:linear-gradient(135deg,var(--bg2),var(--bg3));
  border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:40px 5%; position:relative; z-index:2 }
.statsbar::before { content:''; position:absolute; inset:0;
  background:linear-gradient(90deg,transparent,rgba(0,102,255,.04),transparent); animation:shimmer 4s ease infinite }
@keyframes shimmer { 0%,100%{opacity:0} 50%{opacity:1} }
.sgrid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; max-width:900px; margin:0 auto }
.si { padding:20px; text-align:center; border-right:1px solid var(--border);
  transition:all .6s ease; opacity:1; transform:translateY(0) }
.si:last-child { border-right:none }
.si.an .snum { animation:numPop .5s ease }
@keyframes numPop { 0%{transform:scale(.8);opacity:.5} 100%{transform:scale(1);opacity:1} }
.snum { font-family:var(--font-h); font-size:2.8rem; font-weight:900; color:var(--blue); display:block; line-height:1; margin-bottom:6px }
.slbl { font-family:var(--font-m); font-size:.68rem; color:var(--gray); text-transform:uppercase; letter-spacing:2px }

#hizmetler { background:linear-gradient(180deg,var(--bg0) 0%,var(--bg2) 100%) }
.svgrid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:22px; max-width:1280px; margin:0 auto }
.svc { background:var(--card); border:1px solid var(--border); border-radius:16px;
  padding:32px 24px; text-align:center; transition:all var(--tr); cursor:default;
  backdrop-filter:blur(16px); position:relative; overflow:hidden; display:flex; flex-direction:column; align-items:center }
.svc.link { cursor:pointer }
.svc::before { content:''; position:absolute; inset:0; opacity:0; transition:opacity var(--tr);
  background:linear-gradient(135deg,rgba(0,102,255,.06) 0%,transparent 55%) }
.svc:hover { transform:translateY(-8px); border-color:var(--border-h); box-shadow:var(--glow),var(--shadow) }
.svc:hover::before { opacity:1 }
.sico { width:70px; height:70px; margin:0 auto 18px; background:rgba(0,102,255,.08);
  border-radius:16px; display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(0,102,255,.16); transition:all var(--tr); font-size:2.1rem }
.svc:hover .sico { background:rgba(0,102,255,.18); transform:rotate(-6deg) scale(1.12); box-shadow:0 0 28px var(--blue-g) }
.svc h3 { font-family:var(--font-h); font-size:1.1rem; font-weight:800; margin-bottom:10px }
.svc p { font-size:.87rem; color:var(--gray-l); line-height:1.65 }
.stag-sm { display:inline-block; margin-top:14px; padding:4px 13px; border-radius:50px;
  font-family:var(--font-m); font-size:.65rem; color:var(--blue-l);
  background:rgba(0,102,255,.08); border:1px solid rgba(0,102,255,.16) }
.stag-orange { color:var(--orange-l); background:rgba(255,68,0,.08); border-color:rgba(255,68,0,.2) }
.svc-more { margin-top:14px; font-size:.78rem; color:var(--blue-l); font-weight:700; font-family:var(--font-h) }

/* ENDÜSTRİYEL BANNER */
.ind-banner { max-width:1280px; margin:48px auto 0; background:linear-gradient(135deg,rgba(255,68,0,.08),rgba(0,102,255,.06));
  border:1px solid rgba(255,68,0,.25); border-radius:18px; padding:36px; display:flex; gap:32px; align-items:center; flex-wrap:wrap }
.ind-banner-text { flex:1; min-width:260px }
.ind-banner-text h3 { font-family:var(--font-h); font-size:1.6rem; font-weight:900; margin-bottom:10px }
.ind-banner-text h3 em { color:var(--orange); font-style:normal }
.ind-banner-text p { color:var(--gray-l); font-size:.95rem; line-height:1.75 }
.ind-banner .btn { flex-shrink:0 }

#bolgeler { background:linear-gradient(180deg,var(--bg2) 0%,var(--bg1) 100%) }
.rgrid { display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:14px; max-width:1100px; margin:0 auto 55px }
.rc { background:var(--card); border:1px solid var(--border); border-radius:13px;
  padding:20px 14px; text-align:center; transition:all var(--tr); cursor:pointer; position:relative; overflow:hidden; display:block }
.rc::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--blue),var(--orange)); transform:scaleX(0); transition:transform var(--tr) }
.rc:hover { border-color:var(--border-h); transform:translateY(-5px); box-shadow:var(--glow) }
.rc:hover::after { transform:scaleX(1) }
.rc .rico { font-size:1.8rem; margin-bottom:9px; display:block }
.rc h3 { font-family:var(--font-h); font-size:.95rem; font-weight:800; margin-bottom:5px; color:var(--white) }
.rc p { font-size:.73rem; color:var(--gray) }
.rc small { display:block; margin-top:8px; font-size:.7rem; color:var(--blue-l); font-family:var(--font-m) }
.seo-block { max-width:920px; margin:0 auto; background:var(--card); border:1px solid var(--border); border-radius:16px; padding:40px; line-height:1.9 }
.seo-block h3 { font-family:var(--font-h); font-size:1.1rem; font-weight:800; color:var(--white); margin-bottom:14px }
.seo-block p { font-size:.87rem; color:var(--gray-l); margin-bottom:12px }
.seo-block strong { color:var(--white) }
.seo-block a { color:var(--blue-l) }

#hakkimizda { background:var(--bg2) }
.agrid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; max-width:1200px; margin:0 auto }
.atext h2 { font-family:var(--font-h); font-size:clamp(1.6rem,2.8vw,2.4rem); font-weight:900; line-height:1.15; margin-bottom:20px }
.atext p { color:var(--gray-l); line-height:1.85; margin-bottom:14px; font-size:.97rem }
.flist { list-style:none; margin:26px 0; display:flex; flex-direction:column; gap:12px }
.flist li { display:flex; align-items:center; gap:14px; font-weight:700; font-family:var(--font-h); font-size:.92rem; color:var(--gray-l) }
.flist li::before { content:'✓'; display:flex; align-items:center; justify-content:center;
  min-width:26px; height:26px; border-radius:50%; background:rgba(0,102,255,.12);
  color:var(--blue-l); font-size:.8rem; flex-shrink:0; border:1px solid rgba(0,102,255,.2) }

#galeri { background:var(--bg1); overflow:hidden }
.ggrid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1200px; margin:0 auto }
.gi { background:var(--card); border:1px solid var(--border); border-radius:18px;
  overflow:hidden; transition:all var(--tr); aspect-ratio:4/3; position:relative }
.gi:hover { transform:translateY(-10px) scale(1.02); border-color:var(--border-h); box-shadow:var(--glow),var(--shadow) }
.gi svg { width:100%; height:100%; display:block }
.gi-label { position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(0deg,rgba(3,8,15,.95) 0%,transparent 100%);
  padding:30px 18px 14px; font-family:var(--font-h); font-size:.95rem; font-weight:800; text-align:center; letter-spacing:.3px }

#yorumlar { background:linear-gradient(180deg,var(--bg1) 0%,var(--bg2) 100%) }
.ygrid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px; max-width:1100px; margin:0 auto }
.ycard { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:28px; transition:all var(--tr) }
.ycard:hover { border-color:var(--border-h); transform:translateY(-6px); box-shadow:var(--glow) }
.ystars { display:flex; gap:3px; margin-bottom:14px }
.ystars span { color:var(--gold); font-size:1rem }
.ytext { color:var(--gray-l); font-size:.92rem; line-height:1.75; margin-bottom:18px; font-style:italic }
.ytext::before { content:'❝ '; color:var(--blue-l); font-style:normal }
.ytext::after { content:' ❞'; color:var(--blue-l); font-style:normal }
.yauthor { display:flex; align-items:center; gap:12px }
.yavatar { width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--blue),var(--orange));
  display:flex; align-items:center; justify-content:center; font-family:var(--font-h); font-weight:900; font-size:1rem; flex-shrink:0 }
.yname { font-family:var(--font-h); font-weight:800; font-size:.92rem }
.yinfo { font-size:.75rem; color:var(--gray); margin-top:2px }
.yverified { display:inline-flex; align-items:center; gap:4px; font-size:.7rem; color:var(--green); margin-top:3px; font-family:var(--font-m) }
.gscore { max-width:1100px; margin:40px auto 0; background:var(--card); border:1px solid var(--border);
  border-radius:14px; padding:24px 32px; display:flex; align-items:center; gap:28px; flex-wrap:wrap }
.gsbig { font-family:var(--font-h); font-size:3.5rem; font-weight:900; color:var(--blue); line-height:1 }
.gsright { flex:1 }
.gsright .stars-row { display:flex; gap:4px; margin-bottom:7px }
.gsright .stars-row span { color:var(--gold); font-size:1.3rem }
.gsright p { color:var(--gray-l); font-size:.88rem }
.gsright p strong { color:var(--white) }
.google-badge { margin-left:auto; display:flex; align-items:center; gap:9px; font-family:var(--font-h); font-weight:700; color:var(--gray-l); font-size:.83rem }

#fiyatlar { background:var(--bg2) }
.fgr { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; max-width:1100px; margin:0 auto }
.fcard { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:28px 22px; text-align:center; transition:all var(--tr) }
.fcard:hover { border-color:var(--border-h); transform:translateY(-6px); box-shadow:var(--glow) }
.fcard.featured { border-color:var(--blue); box-shadow:var(--glow) }
.fcard .fdev { font-size:2rem; margin-bottom:12px; display:block }
.fcard h3 { font-family:var(--font-h); font-size:1rem; font-weight:800; margin-bottom:10px }
.fcard .fprice { font-family:var(--font-h); font-size:1.6rem; font-weight:900; color:var(--blue); display:block; margin-bottom:5px }
.fcard .fdesc { font-size:.8rem; color:var(--gray); line-height:1.65 }
.fcard .fgaranti { display:inline-block; margin-top:12px; padding:4px 12px; border-radius:50px;
  font-size:.72rem; font-weight:700; background:rgba(0,204,102,.1); border:1px solid rgba(0,204,102,.25); color:var(--green); font-family:var(--font-m) }
.price-note-block { max-width:1100px; margin:22px auto 0; background:rgba(255,204,0,.06);
  border:1px solid rgba(255,204,0,.18); border-radius:10px; padding:16px 22px;
  font-size:.85rem; color:rgba(255,220,100,.8); font-family:var(--font-h); font-weight:700 }

#harita { background:var(--bg1); padding-bottom:0 }
.map-wrap { max-width:1200px; margin:0 auto; border-radius:18px; overflow:hidden;
  border:1px solid var(--border); box-shadow:var(--shadow) }
.map-wrap iframe { width:100%; height:420px; display:block; border:none; filter:invert(.9) hue-rotate(180deg) saturate(0.7) }
.map-info { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr);
  gap:0; background:var(--card); border:1px solid var(--border); border-top:none;
  border-radius:0 0 18px 18px; overflow:hidden }
.minfo-item { padding:22px; text-align:center; border-right:1px solid var(--border) }
.minfo-item:last-child { border-right:none }
.minfo-item h4 { font-family:var(--font-h); font-size:.92rem; font-weight:800; margin-bottom:5px }
.minfo-item p { font-size:.82rem; color:var(--gray) }

#randevu { background:linear-gradient(180deg,var(--bg1) 0%,var(--bg2) 100%) }
.apwrap { max-width:920px; margin:0 auto; background:var(--card); border:1px solid var(--border);
  border-radius:22px; overflow:hidden; backdrop-filter:blur(24px); box-shadow:var(--shadow),0 0 80px rgba(0,102,255,.08) }
.aphdr { background:linear-gradient(135deg,#0044cc,#0066ff 50%,#0033aa); padding:36px 44px; text-align:center; position:relative; overflow:hidden }
.aphdr::before { content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 20px); pointer-events:none }
.aphdr h2 { font-family:var(--font-h); font-size:2rem; font-weight:900; margin-bottom:8px }
.aphdr p { color:rgba(255,255,255,.75); font-size:.92rem }

.stepin { display:flex; padding:28px 44px; border-bottom:1px solid var(--border); position:relative; background:rgba(0,0,0,.15) }
.stepin::before { content:''; position:absolute; top:50%; left:90px; right:90px; height:1px; background:var(--border); transform:translateY(-50%); z-index:0 }
.stp { flex:1; text-align:center; position:relative; z-index:1 }
.stpc { width:40px; height:40px; border-radius:50%; background:var(--bg0); border:2px solid var(--border);
  display:flex; align-items:center; justify-content:center; font-family:var(--font-h); font-weight:800; font-size:.88rem; margin:0 auto 7px; transition:all var(--tr); color:var(--gray) }
.stp.act .stpc { background:var(--blue); border-color:var(--blue); color:#fff; box-shadow:0 0 24px var(--blue-g) }
.stp.done .stpc { background:var(--green); border-color:var(--green); color:#fff }
.stplbl { font-family:var(--font-m); font-size:.65rem; color:var(--gray); letter-spacing:.5px; text-transform:uppercase }
.stp.act .stplbl { color:var(--blue-l) }
.stp.done .stplbl { color:var(--green) }

.fstep { display:none; padding:38px 44px; animation:stepin .4s cubic-bezier(.4,0,.2,1) }
.fstep.act { display:block }
@keyframes stepin { from{opacity:0;transform:translateX(24px)} to{opacity:1;transform:translateX(0)} }

.devgrid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:22px }
.devopt { background:rgba(255,255,255,.04); border:2px solid var(--border); border-radius:12px;
  padding:18px 8px; text-align:center; cursor:pointer; transition:all var(--tr);
  display:flex; flex-direction:column; align-items:center; gap:8px }
.devopt:hover { border-color:rgba(0,102,255,.4); background:rgba(0,102,255,.05) }
.devopt.sel { border-color:var(--blue); background:rgba(0,102,255,.1); box-shadow:0 0 20px var(--blue-g) }
.devopt .dice { font-size:2rem; display:block }
.devopt .dlbl { font-family:var(--font-h); font-size:.73rem; font-weight:800; color:var(--gray-l); letter-spacing:.3px }
.devopt.sel .dlbl { color:var(--white) }

.probchips { display:flex; flex-wrap:wrap; gap:9px; margin:14px 0 22px }
.chip { background:rgba(255,255,255,.04); border:1px solid var(--border); border-radius:50px;
  padding:8px 16px; font-size:.8rem; font-weight:700; font-family:var(--font-h);
  color:var(--gray-l); cursor:pointer; transition:all var(--tr) }
.chip:hover { border-color:rgba(0,102,255,.4); color:var(--white) }
.chip.sel { background:rgba(0,102,255,.12); border-color:var(--blue); color:var(--blue-l) }

.tgrid { display:grid; grid-template-columns:repeat(5,1fr); gap:9px; margin-top:14px }
.ts { background:rgba(255,255,255,.04); border:1px solid var(--border); border-radius:8px;
  padding:12px 6px; text-align:center; cursor:pointer; transition:all var(--tr); font-family:var(--font-m); font-size:.82rem; font-weight:700 }
.ts:hover:not(.bkd) { border-color:var(--border-h); background:rgba(0,102,255,.07); color:var(--blue-l) }
.ts.sel { background:var(--blue); border-color:var(--blue); color:#fff; box-shadow:0 0 18px var(--blue-g) }
.ts.bkd { opacity:.35; cursor:not-allowed; background:rgba(255,68,0,.04); border-color:rgba(255,68,0,.15); color:var(--gray); position:relative }
.ts.bkd::before { content:'✕'; position:absolute; top:2px; right:4px; font-size:.5rem; color:var(--orange) }

.frow { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px }
.fg { margin-bottom:18px }
.fg label { display:block; font-family:var(--font-h); font-size:.8rem; font-weight:800;
  color:var(--gray-l); margin-bottom:8px; letter-spacing:.5px; text-transform:uppercase }
.fg label em { color:var(--orange); font-style:normal }
.fg input,.fg select,.fg textarea { width:100%; background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:8px; padding:13px 16px; color:var(--white); font-family:var(--font-b); font-size:.93rem; transition:all var(--tr); outline:none }
.fg input:focus,.fg select:focus,.fg textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-g); background:rgba(0,102,255,.04) }
.fg input::placeholder,.fg textarea::placeholder { color:var(--gray) }
.fg select option { background:var(--bg2); color:var(--white) }
.fg textarea { min-height:120px; resize:vertical; line-height:1.65 }

.fnav { display:flex; justify-content:space-between; align-items:center; padding-top:26px; border-top:1px solid var(--border); margin-top:22px }
.bfm { display:inline-flex; align-items:center; gap:9px; padding:13px 28px; border-radius:9px;
  font-family:var(--font-h); font-weight:800; font-size:.9rem; border:none; transition:all var(--tr); letter-spacing:.4px }
.bnxt { background:var(--blue); color:#fff; margin-left:auto; box-shadow:0 0 30px var(--blue-g) }
.bnxt:hover { background:var(--blue-l); transform:translateY(-2px) }
.bprv { background:transparent; color:var(--gray-l); border:1px solid var(--border)!important; cursor:pointer }
.bprv:hover { border-color:var(--blue-l)!important; color:var(--white) }
.bsub { background:linear-gradient(135deg,var(--blue),#0033bb); color:#fff; margin-left:auto;
  box-shadow:0 0 40px var(--blue-g); font-size:1rem; padding:16px 40px }
.bsub:hover { transform:translateY(-2px); box-shadow:0 14px 50px var(--blue-g) }

.sumbox { background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:12px; padding:22px; margin:16px 0 }
.sumrow { display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px solid rgba(255,255,255,.05); font-size:.88rem; gap:14px }
.sumrow:last-child { border-bottom:none }
.sumrow .lbl { color:var(--gray); font-weight:700; font-family:var(--font-h); flex-shrink:0 }
.sumrow .val { color:var(--white); font-weight:700; text-align:right }

.succ { display:none; text-align:center; padding:60px 44px; animation:stepin .5s ease }
.succico { width:82px; height:82px; background:rgba(0,204,102,.1); border:2px solid var(--green);
  border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:2.6rem;
  margin:0 auto 22px; animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1) .2s both }
@keyframes scaleIn { from{transform:scale(0)} to{transform:scale(1)} }
.succ h3 { font-family:var(--font-h); font-size:1.9rem; font-weight:900; margin-bottom:14px }
.succ p { color:var(--gray-l); line-height:1.8; max-width:420px; margin:0 auto 28px }

/* FAQ Accordion */
#sss { background:var(--bg1) }
.faq-wrap { max-width:880px; margin:0 auto; display:flex; flex-direction:column; gap:12px }
.faq-item { background:var(--card); border:1px solid var(--border); border-radius:12px; overflow:hidden; transition:all var(--tr) }
.faq-item:hover { border-color:var(--border-h) }
.faq-q { padding:20px 24px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:14px; font-family:var(--font-h); font-weight:800; font-size:.97rem; line-height:1.45 }
.faq-q::after { content:'+'; font-family:var(--font-h); font-size:1.6rem; color:var(--blue-l); flex-shrink:0; transition:transform var(--tr) }
.faq-item.open .faq-q::after { transform:rotate(45deg) }
.faq-a { max-height:0; overflow:hidden; padding:0 24px; transition:all var(--tr); color:var(--gray-l); font-size:.92rem; line-height:1.8 }
.faq-item.open .faq-a { max-height:600px; padding:0 24px 20px }

#iletisim { background:var(--bg2) }
.cgrid { display:grid; grid-template-columns:1fr 1fr; gap:60px; max-width:1020px; margin:0 auto; align-items:start }
.cinfo h2 { font-family:var(--font-h); font-size:clamp(1.6rem,2.5vw,2.2rem); font-weight:900; margin-bottom:20px }
.cinfo p { color:var(--gray-l); line-height:1.85; margin-bottom:30px }
.clinks { display:flex; flex-direction:column; gap:13px }
.clink { display:flex; align-items:center; gap:15px; padding:16px 18px;
  background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:12px;
  transition:all var(--tr); font-weight:700; color:var(--white) }
.clink:hover { border-color:var(--border-h); transform:translateX(6px); box-shadow:var(--glow) }
.clico { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.25rem; flex-shrink:0 }
.bl { background:rgba(0,102,255,.15) }
.gn { background:rgba(37,211,102,.15) }
.ig { background:rgba(225,48,108,.15) }
.or { background:rgba(255,85,0,.15) }
.clinfo { flex:1 }
.clinfo small { display:block; font-family:var(--font-m); font-size:.65rem; color:var(--gray); letter-spacing:1px; margin-bottom:2px; text-transform:uppercase }
.carrw { color:var(--gray); font-size:.8rem; margin-left:auto }
.infocard { background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:16px; padding:28px }
.infocard h3 { font-family:var(--font-h); font-size:1.05rem; font-weight:800; margin-bottom:18px }
.hrrow { display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--border); font-size:.9rem }
.hrrow:last-child { border-bottom:none }
.hrrow span:first-child { color:var(--gray-l); font-weight:700 }
.hrrow span:last-child { color:var(--blue-l); font-weight:800 }
.hrrow .orng { color:var(--orange) !important }
.bcard { background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:16px; padding:24px; margin-top:16px }
.bcard h3 { font-family:var(--font-h); font-size:1rem; font-weight:800; margin-bottom:11px }
.bcard p { color:var(--gray); font-size:.83rem; line-height:1.7 }

.notice { background:rgba(255,68,0,.07); border:1px solid rgba(255,68,0,.2); border-radius:8px;
  padding:12px 18px; font-size:.83rem; color:rgba(255,160,100,.85); margin-bottom:20px; font-family:var(--font-h); font-weight:700 }

.floats { position:fixed; bottom:26px; right:24px; display:flex; flex-direction:column; gap:11px; z-index:900 }
.fbtn { width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:1.35rem; transition:all var(--tr); box-shadow:0 4px 24px rgba(0,0,0,.4);
  border:none; cursor:pointer; position:relative; color:#fff }
.fbtn::before { content:attr(data-tip); position:absolute; right:68px; background:rgba(3,8,15,.92);
  border:1px solid var(--border); padding:7px 14px; border-radius:7px; font-family:var(--font-h);
  font-size:.8rem; font-weight:700; white-space:nowrap; opacity:0; pointer-events:none;
  transition:opacity var(--tr); backdrop-filter:blur(12px) }
.fbtn:hover::before { opacity:1 }
.fbtn:hover { transform:scale(1.12) }
.fwa { background:#25d366; box-shadow:0 4px 24px rgba(37,211,102,.3) }
.fph { background:var(--blue); box-shadow:0 4px 24px var(--blue-g) }
.ftop { background:var(--bg3); border:1px solid var(--border); font-size:.9rem; font-family:var(--font-h); font-weight:800 }

footer { background:var(--bg2); border-top:1px solid var(--border); padding:60px 5% 28px; position:relative; z-index:2 }
.fgrid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:36px; max-width:1200px; margin:0 auto 46px }
.fbrand p { color:var(--gray); font-size:.87rem; line-height:1.75; margin:14px 0 18px }
.socials { display:flex; gap:10px }
.sol { width:38px; height:38px; border-radius:8px; background:rgba(255,255,255,.05); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; color:var(--gray); font-size:.95rem; transition:all var(--tr) }
.sol:hover { background:rgba(0,102,255,.1); border-color:var(--blue); color:var(--white) }
.fcol h4 { font-family:var(--font-h); font-size:.95rem; font-weight:800; margin-bottom:18px; letter-spacing:.5px; color:var(--white) }
.flinks { list-style:none; display:flex; flex-direction:column; gap:9px }
.flinks a { color:var(--gray); font-size:.87rem; transition:color var(--tr) }
.flinks a:hover { color:var(--blue-l) }
.fbot { max-width:1200px; margin:0 auto; padding-top:24px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px }
.fbot p { color:var(--gray); font-size:.8rem }
.fbot a { color:var(--blue-l) }
.fseo { max-width:1200px; margin:18px auto 0; padding-top:20px; border-top:1px solid var(--border) }
.fseo p { color:rgba(90,112,144,.4); font-size:.73rem; line-height:1.75; text-align:center }

/* Sub page hero */
.sub-hero { padding:130px 5% 80px; position:relative; overflow:hidden; background:linear-gradient(175deg,#03080f 0%,#060d1a 100%); border-bottom:1px solid var(--border) }
.sub-hero::before { content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 50% at 70% 30%, rgba(0,60,180,.15) 0%, transparent 60%),
             radial-gradient(ellipse 40% 30% at 20% 80%, rgba(255,68,0,.08) 0%, transparent 55%) }
.sub-hero::after { content:''; position:absolute; inset:0; opacity:.05;
  background-image:linear-gradient(rgba(0,102,255,.4) 1px, transparent 1px),
                   linear-gradient(90deg, rgba(0,102,255,.4) 1px, transparent 1px);
  background-size:60px 60px }
.sub-hero-inner { max-width:1100px; margin:0 auto; position:relative; z-index:2; text-align:center }
.sub-hero h1 { font-family:var(--font-h); font-size:clamp(2.2rem,4.5vw,3.5rem); font-weight:900; line-height:1.12; margin:18px 0 22px }
.sub-hero h1 em { color:var(--blue); font-style:normal }
.sub-hero p { color:var(--gray-l); font-size:1.05rem; line-height:1.85; max-width:740px; margin:0 auto 32px }
.sub-hero p strong { color:var(--white) }

/* Article content */
.article-content { max-width:880px; margin:0 auto; padding:80px 5% }
.article-content h2 { font-family:var(--font-h); font-size:1.8rem; font-weight:900; margin:36px 0 16px; line-height:1.25 }
.article-content h2 em { color:var(--blue); font-style:normal }
.article-content h3 { font-family:var(--font-h); font-size:1.3rem; font-weight:800; margin:28px 0 12px }
.article-content p { color:var(--gray-l); font-size:1rem; line-height:1.9; margin-bottom:14px }
.article-content p strong { color:var(--white) }
.article-content ul { margin:14px 0 24px 0; padding-left:0; list-style:none }
.article-content ul li { padding:8px 0 8px 30px; position:relative; color:var(--gray-l); font-size:.95rem; line-height:1.7 }
.article-content ul li::before { content:'✓'; position:absolute; left:0; top:9px;
  width:20px; height:20px; background:rgba(0,102,255,.15); border:1px solid rgba(0,102,255,.3);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.7rem; color:var(--blue-l); font-weight:700 }
.article-content a { color:var(--blue-l); font-weight:700 }
.article-content a:hover { text-decoration:underline }

.cta-strip { max-width:1100px; margin:50px auto; background:linear-gradient(135deg,#0044cc,#0066ff 60%,#0033aa);
  border-radius:18px; padding:42px; text-align:center; position:relative; overflow:hidden }
.cta-strip::before { content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 20px) }
.cta-strip h2 { position:relative; font-family:var(--font-h); font-size:clamp(1.4rem,2.5vw,2rem); font-weight:900; margin-bottom:10px }
.cta-strip p { position:relative; color:rgba(255,255,255,.85); font-size:1rem; margin-bottom:24px }
.cta-strip-btns { position:relative; display:flex; justify-content:center; gap:14px; flex-wrap:wrap }

/* Region cross-link bar */
.region-links { max-width:1200px; margin:50px auto; padding:32px; background:var(--card); border:1px solid var(--border); border-radius:18px }
.region-links h3 { font-family:var(--font-h); font-size:1.1rem; font-weight:800; margin-bottom:16px; text-align:center }
.region-links-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:10px }
.region-links-grid a { padding:11px 14px; background:rgba(0,102,255,.05); border:1px solid var(--border);
  border-radius:8px; font-family:var(--font-h); font-weight:700; font-size:.83rem; text-align:center;
  color:var(--gray-l); transition:all var(--tr) }
.region-links-grid a:hover { background:rgba(0,102,255,.12); color:var(--white); border-color:var(--border-h); transform:translateY(-2px) }

@media(max-width:1100px){ .hero-visual{width:360px} }
@media(max-width:980px){
  .hero-visual{display:none} .ggrid{grid-template-columns:repeat(2,1fr)}
  .fgrid{grid-template-columns:1fr 1fr} .agrid{grid-template-columns:1fr;gap:38px} .aimg{display:none}
  .map-info{grid-template-columns:1fr}
  .minfo-item{border-right:none;border-bottom:1px solid var(--border)}
  .minfo-item:last-child{border-bottom:none}
  .ind-banner{padding:28px}
}
@media(max-width:768px){
  section{padding:65px 5%}
  nav .nlinks{display:none} .hbg{display:flex}
  .sgrid{grid-template-columns:repeat(2,1fr)}
  .si{border-right:none;border-bottom:1px solid var(--border)}
  .si:nth-child(odd){border-right:1px solid var(--border)}
  .devgrid{grid-template-columns:repeat(3,1fr)} .tgrid{grid-template-columns:repeat(4,1fr)}
  .frow{grid-template-columns:1fr} .ggrid{grid-template-columns:1fr}
  .cgrid{grid-template-columns:1fr;gap:38px} .fgrid{grid-template-columns:1fr}
  .fbot{flex-direction:column;text-align:center}
  .aphdr,.fstep{padding:22px 18px} .stepin{padding:18px} .stplbl{display:none}
  .hbtns{flex-direction:column;gap:10px}
  .hbtns .btn-primary,.hbtns .btn-secondary{width:100%;justify-content:center}
  .hbtns .wa-icon-btn{width:52px;height:52px;align-self:flex-start}
  .floats{bottom:14px;right:12px}
  .fnav{flex-wrap:wrap;gap:10px} .bnxt,.bsub{margin-left:0;width:100%;justify-content:center}
  .succ{padding:38px 18px}
  .fgr{grid-template-columns:repeat(2,1fr)}
  .map-wrap iframe{height:300px}
  .gscore{flex-direction:column;text-align:center}
  .google-badge{margin-left:0}
  .article-content{padding:60px 5%}
  .article-content h2{font-size:1.5rem}
  .cta-strip{padding:32px 22px}
  .bcrumb{padding:74px 5% 14px}
}
@media(max-width:480px){
  .devgrid{grid-template-columns:repeat(2,1fr)} .tgrid{grid-template-columns:repeat(3,1fr)}
  .htitle{font-size:2.1rem}
  .sgrid{grid-template-columns:1fr} .si:nth-child(odd){border-right:none}
  .rgrid{grid-template-columns:repeat(2,1fr)} .fgr{grid-template-columns:1fr}
}

/* Google yorumları (gerçek — API veya reviews.json) */
#google-reviews-root { max-width:1100px; margin:0 auto }
.gr-actions { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin:28px 0 20px }
.gr-live-note { text-align:center; color:var(--gray-l); font-size:.95rem; margin-bottom:8px }
.gr-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:22px; margin-top:24px }
.gr-card { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:24px; transition:all var(--tr) }
.gr-card:hover { border-color:var(--border-h); transform:translateY(-4px) }
.gr-stars { color:#fbbc04; font-size:1rem; letter-spacing:2px; margin-bottom:12px }
.gr-text { color:var(--gray-l); font-size:.92rem; line-height:1.75; margin-bottom:16px }
.gr-author { display:flex; align-items:center; gap:12px }
.gr-avatar { width:40px; height:40px; border-radius:50%; background:var(--bg3); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; font-weight:800; color:var(--blue-l); flex-shrink:0 }
.gr-author strong { display:block; color:var(--white); font-size:.88rem }
.gr-author span { font-size:.75rem; color:var(--gray) }
.gr-empty { text-align:center; padding:32px 20px; color:var(--gray-l); background:var(--card);
  border:1px dashed var(--border); border-radius:14px; margin-top:20px }
.gr-map-wrap { margin-top:36px; border-radius:16px; overflow:hidden; border:1px solid var(--border) }
.gr-map-wrap iframe { width:100%; height:360px; border:0; display:block }
