/* ============================================================
   GOPOS ÖZELLİKLER SAYFASI
   ============================================================ */

/* Renkli section-tag varyantları */
.section-tag--blue   { color: var(--gp-blue);   background: var(--gp-blue-soft); }
.section-tag--blue::before   { background: var(--gp-blue); }
.section-tag--green  { color: var(--gp-teal);   background: var(--gp-teal-soft); }
.section-tag--green::before  { background: var(--gp-teal); }
.section-tag--teal   { color: var(--gp-cyan);   background: var(--gp-cyan-soft); }
.section-tag--teal::before   { background: var(--gp-cyan); }
.section-tag--purple { color: var(--gp-purple); background: var(--gp-purple-soft); }
.section-tag--purple::before { background: var(--gp-purple); }
.section-tag--pink   { color: var(--gp-pink);   background: var(--gp-pink-soft); }
.section-tag--pink::before   { background: var(--gp-pink); }
.section-tag--orange { color: var(--gp-primary); background: var(--gp-primary-soft); }
.section-tag--orange::before { background: var(--gp-primary); }

/* ── Hero ─────────────────────────────────────────────────── */
.gp-feat-hero {
  background: radial-gradient(ellipse 70% 90% at 50% 0%, var(--gp-primary-tint) 0%, transparent 70%), var(--gp-bg-soft);
  padding: clamp(3.5rem, 8vw, 6.5rem) 0 clamp(3rem, 6vw, 5rem);
  text-align: center;
}
.gp-feat-hero__inner { max-width: 760px; margin-inline: auto; }
.gp-feat-hero__title { font-size: clamp(var(--text-xl), 2.6vw, var(--text-3xl)); font-weight: 800; color: var(--gp-ink); letter-spacing: -.02em; line-height: 1.2; margin: var(--space-4) 0 var(--space-5); }
.gp-feat-hero__desc { font-size: var(--text-lg); color: var(--gp-mute); line-height: 1.7; }
.gp-feat-hero__cta { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--space-8); }

/* Kurye firması kartları */
.gp-courier-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
.gp-courier-card { background: #fff; border: 1px solid var(--gp-line); border-radius: var(--radius-lg); padding: var(--space-6) var(--space-4); text-align: center; transition: all var(--transition); }
.gp-courier-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: transparent; }
.gp-courier-card.is-own { border-color: var(--gp-primary); box-shadow: var(--shadow-primary); }
.gp-courier-card__ico { width: 52px; height: 52px; margin: 0 auto var(--space-3); display: flex; align-items: center; justify-content: center; border-radius: var(--radius-md); background: var(--gp-bg-soft); color: var(--gp-primary); }
.gp-courier-card.is-own .gp-courier-card__ico { background: var(--gp-primary); color: #fff; }
.gp-courier-card__ico .gp-ico { width: 26px; height: 26px; }
.gp-courier-card__name { display: block; font-size: var(--text-base); font-weight: 800; color: var(--gp-ink); margin-bottom: 4px; }
.gp-courier-card__tag { font-size: var(--text-xs); font-weight: 700; color: var(--gp-primary); }
@media (max-width: 900px) { .gp-courier-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .gp-courier-grid { grid-template-columns: repeat(2, 1fr); } }

/* Paket servis — entegrasyon platform rozetleri */
.gp-ps-platforms { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; margin-top: var(--space-8); }
.gp-ps-platforms .legal-chip { background: #fff; border: 1px solid var(--gp-line); box-shadow: var(--shadow-sm); }

/* ── Paket Servis — görselli dönüşümlü satırlar ───────────── */
.gp-ps-rows { padding-top: 0; }
.gp-ps-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,6vw,5rem); align-items: center; margin-bottom: clamp(3.5rem,8vw,7rem); }
.gp-ps-row:last-child { margin-bottom: 0; }
.gp-ps-row--reverse .gp-ps-row__text { order: 2; }

.gp-ps-row__badge { width: 56px; height: 56px; display: inline-flex; align-items: center; justify-content: center; border-radius: var(--radius-md); background: var(--gp-bg-soft); margin-bottom: var(--space-5); }
.gp-ps-row__badge .gp-ico { width: 30px; height: 30px; }
.gp-ps-row--orange .gp-ps-row__badge { background: var(--gp-primary-soft); }
.gp-ps-row--blue   .gp-ps-row__badge { background: var(--gp-blue-soft); }
.gp-ps-row--pink   .gp-ps-row__badge { background: var(--gp-pink-soft); }
.gp-ps-row--teal   .gp-ps-row__badge { background: var(--gp-cyan-soft); }
.gp-ps-row--purple .gp-ps-row__badge { background: var(--gp-purple-soft); }

.gp-ps-row__title { font-size: clamp(var(--text-2xl),3vw,var(--text-4xl)); font-weight: 800; color: var(--gp-ink); letter-spacing: -.03em; line-height: 1.15; margin-bottom: var(--space-4); }
.gp-ps-row__desc { font-size: var(--text-lg); color: var(--gp-mute); line-height: 1.8; margin-bottom: var(--space-6); }
.gp-ps-row__link { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: 700; color: var(--gp-primary); transition: gap var(--transition-fast); }
.gp-ps-row__link:hover { gap: var(--space-3); }

/* Modern çerçeveli görsel */
.gp-ps-row__media { display: flex; align-items: center; justify-content: center; }
.gp-ps-frame { position: relative; width: 100%; max-width: 540px; }
.gp-ps-frame__blob { position: absolute; width: 70%; height: 70%; border-radius: 42% 58% 60% 40% / 45% 45% 55% 55%; background: var(--grad-primary); opacity: .14; top: -8%; right: -6%; z-index: 0; }
.gp-ps-row--blue   .gp-ps-frame__blob { background: var(--grad-blue); }
.gp-ps-row--pink   .gp-ps-frame__blob { background: linear-gradient(135deg,#FF7BAC,#FF4D8D); }
.gp-ps-row--teal   .gp-ps-frame__blob { background: var(--grad-teal); }
.gp-ps-row--purple .gp-ps-frame__blob { background: var(--grad-purple); }
.gp-ps-frame__ring { position: absolute; width: 64px; height: 64px; border-radius: 50%; border: 10px solid var(--gp-primary-soft); bottom: -18px; left: -18px; z-index: 0; }
.gp-ps-row--blue   .gp-ps-frame__ring { border-color: var(--gp-blue-soft); }
.gp-ps-row--pink   .gp-ps-frame__ring { border-color: var(--gp-pink-soft); }
.gp-ps-row--teal   .gp-ps-frame__ring { border-color: var(--gp-cyan-soft); }
.gp-ps-row--purple .gp-ps-frame__ring { border-color: var(--gp-purple-soft); }

.gp-ps-frame__inner {
    position: relative; z-index: 1;
    background: #fff; border: 1px solid var(--gp-line);
    border-radius: var(--radius-xl); padding: var(--space-3);
    box-shadow: var(--shadow-xl);
    aspect-ratio: 16 / 11; overflow: hidden;
    display: flex; align-items: center; justify-content: center;
}
.gp-ps-frame__inner .gp-ps-img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-lg); display: block; }
.gp-ps-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-3); color: var(--gp-primary); }
.gp-ps-placeholder .gp-ico { width: 56px; height: 56px; opacity: .7; }
.gp-ps-placeholder span { font-size: var(--text-sm); font-weight: 700; color: var(--gp-faint); }

@media (max-width: 860px) {
    .gp-ps-row { grid-template-columns: 1fr; gap: var(--space-6); text-align: center; }
    .gp-ps-row--reverse .gp-ps-row__text { order: 0; }
    .gp-ps-row__badge { margin-inline: auto; }
    .gp-ps-frame { max-width: 460px; margin-inline: auto; }
}

/* ── Gruplar ──────────────────────────────────────────────── */
.gp-feat-group { padding: clamp(3rem, 6vw, 5rem) 0; }
.gp-feat-group--alt { background: var(--gp-bg-soft); }
.gp-feat-group__head { max-width: 720px; margin: 0 auto clamp(2rem, 4vw, 3rem); text-align: center; }
.gp-feat-group__title { font-size: clamp(var(--text-lg), 2.2vw, var(--text-2xl)); font-weight: 800; color: var(--gp-ink); letter-spacing: -.02em; margin: var(--space-3) 0 var(--space-4); }
.gp-feat-group__desc { font-size: var(--text-base); color: var(--gp-mute); line-height: 1.7; }

.gp-feat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-5); }

/* ── QR Menü özel vurgu ───────────────────────────────────── */
.gp-qr-feature { padding: clamp(1rem, 2vw, 2rem) 0 clamp(3rem, 6vw, 5rem); }
.gp-qr-feature__inner {
  position: relative;
  border-radius: var(--radius-2xl);
  padding: clamp(2rem, 5vw, 4rem);
  background:
    radial-gradient(ellipse 70% 100% at 0% 0%, rgba(255,255,255,.14), transparent 55%),
    var(--grad-purple);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
}
.gp-qr-feature__inner::after { content: ''; position: absolute; width: 300px; height: 300px; border-radius: 50%; background: rgba(255,255,255,.10); bottom: -120px; right: -60px; }
.gp-qr-feature__head { position: relative; max-width: 720px; margin: 0 auto clamp(2rem, 4vw, 3rem); text-align: center; }
.gp-qr-feature__head .section-tag--light { background: rgba(255,255,255,.18); color: #fff; }
.gp-qr-feature__head .section-tag--light::before { background: #fff; }
.gp-qr-feature__head h2 { font-size: clamp(var(--text-lg), 2.2vw, var(--text-2xl)); color: #fff; margin: var(--space-3) 0 var(--space-4); }
.gp-qr-feature__head p { font-size: var(--text-base); color: rgba(255,255,255,.85); line-height: 1.7; }

.gp-qr-feature__grid { position: relative; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-3); }
.qr-feat-card { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-4); border-radius: var(--radius-lg); background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.15); backdrop-filter: blur(6px); transition: background var(--transition); }
.qr-feat-card:hover { background: rgba(255,255,255,.18); }
.qr-feat-card__icon { width: 44px; height: 44px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); background: rgba(255,255,255,.18); color: #fff; }
.qr-feat-card__icon .gp-ico { width: 24px; height: 24px; }
.qr-feat-card strong { display: block; font-size: var(--text-sm); font-weight: 800; color: #fff; margin-bottom: 2px; }
.qr-feat-card span { font-size: var(--text-xs); color: rgba(255,255,255,.8); line-height: 1.5; }

.gp-qr-feature__cta { position: relative; display: flex; justify-content: center; margin-top: clamp(2rem, 4vw, 3rem); }

@media (max-width: 560px) {
  .gp-feat-grid { grid-template-columns: 1fr; }
}

/* ── Mobil uygulama — açık zeminde app rozetleri & QR notu ── */
.gp-app-badges--light { justify-content: center; margin-top: var(--space-8); }
.gp-app-badges--light .app-badge { background: #fff; border: 1px solid var(--gp-line); box-shadow: var(--shadow-sm); }
.gp-app-badges--light .app-badge:hover { border-color: var(--gp-line-2); background: #fff; transform: translateY(-2px); box-shadow: var(--shadow); }
.gp-app-badges--light .app-badge__icon { color: var(--gp-ink); }
.gp-app-badges--light .app-badge__text small { color: var(--gp-mute); }
.gp-app-badges--light .app-badge__text strong { color: var(--gp-ink); }
.gp-mobile-qr-note { margin-top: var(--space-5); font-size: var(--text-sm); color: var(--gp-mute); font-weight: 600; }

/* ── Anlık Bildirim animasyonu ────────────────────────────── */
.gp-notif__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,6vw,5rem); align-items: center; }
.gp-notif__title { font-size: clamp(var(--text-lg),2.2vw,var(--text-2xl)); font-weight: 800; color: var(--gp-ink); letter-spacing: -.02em; margin: var(--space-3) 0 var(--space-4); line-height: 1.15; }
.gp-notif__desc { font-size: var(--text-lg); color: var(--gp-mute); line-height: 1.8; margin-bottom: var(--space-6); }
.gp-notif__list { display: flex; flex-direction: column; gap: var(--space-3); }
.gp-notif__list li { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-sm); font-weight: 600; color: var(--gp-text); }
.gp-notif__list .showcase-check { width: 22px; height: 22px; color: var(--gp-pink); flex-shrink: 0; }

/* Telefon çerçevesi */
.gp-notif__visual { display: flex; justify-content: center; }
.gp-phone {
    position: relative; width: 300px; max-width: 100%;
    background: var(--gp-ink); border-radius: 38px; padding: 12px;
    box-shadow: var(--shadow-xl), 0 0 0 2px rgba(0,0,0,.04);
}
.gp-phone__notch { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); width: 120px; height: 22px; background: var(--gp-ink); border-radius: 0 0 14px 14px; z-index: 3; }
.gp-phone__screen { background: var(--gp-bg-soft); border-radius: 28px; overflow: hidden; min-height: 460px; }
.gp-phone__header { display: flex; align-items: center; gap: var(--space-2); padding: 2.2rem 1.2rem 1rem; font-size: var(--text-sm); font-weight: 800; color: var(--gp-ink); background: #fff; border-bottom: 1px solid var(--gp-line); }
.gp-phone__bell { position: relative; color: var(--gp-primary); display: inline-flex; transform-origin: top center; animation: bell-ring 3s ease-in-out infinite; }
.gp-phone__dot { position: absolute; top: -2px; right: -2px; width: 8px; height: 8px; border-radius: 50%; background: var(--gp-pink); border: 1.5px solid #fff; }
@keyframes bell-ring { 0%,70%,100%{transform:rotate(0);} 75%{transform:rotate(12deg);} 80%{transform:rotate(-10deg);} 85%{transform:rotate(8deg);} 90%{transform:rotate(-6deg);} 95%{transform:rotate(3deg);} }

.gp-phone__feed { padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-3); }

/* Bildirim kartları — sırayla beliren animasyon */
.gp-notif-card {
    display: flex; align-items: flex-start; gap: var(--space-3);
    background: #fff; border: 1px solid var(--gp-line); border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-4); box-shadow: var(--shadow-sm);
    opacity: 0; transform: translateX(16px) scale(.97);
    animation: notif-pop 9s ease-in-out infinite;
}
.gp-notif-card--iade  { animation-delay: 0s;   border-left: 3px solid #F87171; }
.gp-notif-card--ikram { animation-delay: 3s;   border-left: 3px solid var(--gp-teal); }
.gp-notif-card--fiyat { animation-delay: 6s;   border-left: 3px solid var(--gp-primary); }
@keyframes notif-pop {
    0%   { opacity: 0; transform: translateX(16px) scale(.97); }
    4%   { opacity: 1; transform: translateX(0) scale(1); }
    6%   { transform: translateX(0) scale(1.03); }
    9%   { transform: translateX(0) scale(1); }
    30%  { opacity: 1; transform: translateX(0) scale(1); }
    36%  { opacity: .15; transform: translateX(-10px) scale(.98); }
    100% { opacity: .15; transform: translateX(-10px) scale(.98); }
}

.gp-notif-card__ico { width: 34px; height: 34px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); }
.gp-notif-card--iade  .gp-notif-card__ico { background: #FEE2E2; color: #EF4444; }
.gp-notif-card--ikram .gp-notif-card__ico { background: var(--gp-teal-soft); color: var(--gp-teal); }
.gp-notif-card--fiyat .gp-notif-card__ico { background: var(--gp-primary-soft); color: var(--gp-primary); }
.gp-notif-card__ico .gp-ico { width: 20px; height: 20px; }
.gp-notif-card__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.gp-notif-card__tag { align-self: flex-start; font-size: 10px; font-weight: 800; padding: 1px 7px; border-radius: var(--radius-full); letter-spacing: .04em; }
.tag--iade  { background: #FEE2E2; color: #DC2626; }
.tag--ikram { background: var(--gp-teal-soft); color: var(--gp-teal); }
.tag--fiyat { background: var(--gp-primary-soft); color: var(--gp-primary-dark); }
.gp-notif-card__body strong { font-size: var(--text-sm); font-weight: 800; color: var(--gp-ink); }
.gp-notif-card__body span { font-size: var(--text-xs); color: var(--gp-mute); }
.gp-notif-card__time { margin-left: auto; font-size: 10px; color: var(--gp-faint); flex-shrink: 0; }

@media (prefers-reduced-motion: reduce) {
    .gp-notif-card { opacity: 1; transform: none; animation: none; }
    .gp-phone__bell { animation: none; }
    .rc-bar__fill { height: var(--h) !important; animation: none !important; }
}
@media (max-width: 860px) {
    .gp-notif__inner { grid-template-columns: 1fr; text-align: center; }
    .gp-notif__list li { justify-content: center; }
    .gp-notif__visual { order: -1; }
}

/* ── Detaylı Mobil Raporlama ──────────────────────────────── */
.gp-report__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,6vw,5rem); align-items: center; }
.gp-report__title { font-size: clamp(var(--text-lg),2.2vw,var(--text-2xl)); font-weight: 800; color: var(--gp-ink); letter-spacing: -.02em; margin: var(--space-3) 0 var(--space-4); line-height: 1.15; }
.gp-report__desc { font-size: var(--text-lg); color: var(--gp-mute); line-height: 1.8; margin-bottom: var(--space-6); }
.gp-report__list { display: flex; flex-direction: column; gap: var(--space-3); }
.gp-report__list li { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-sm); font-weight: 600; color: var(--gp-text); }
.gp-report__list .showcase-check { width: 22px; height: 22px; color: var(--gp-cyan); flex-shrink: 0; }

/* Rapor kartı */
.gp-report__visual { display: flex; justify-content: center; }
.gp-report-card {
    width: 100%; max-width: 420px;
    background: #fff; border: 1px solid var(--gp-line); border-radius: var(--radius-2xl);
    padding: clamp(1.25rem,3vw,1.75rem); box-shadow: var(--shadow-xl);
}
.gp-report-card__head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-5); flex-wrap: wrap; }
.rc-label { display: block; font-size: var(--text-xs); color: var(--gp-faint); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.rc-range { font-size: var(--text-xl); font-weight: 800; color: var(--gp-ink); }
.rc-pills { display: flex; gap: 4px; background: var(--gp-bg-soft); padding: 4px; border-radius: var(--radius-full); }
.rc-pills span { font-size: 11px; font-weight: 700; color: var(--gp-mute); padding: 5px 10px; border-radius: var(--radius-full); }
.rc-pills .is-active { background: var(--grad-primary); color: #fff; box-shadow: 0 3px 10px -3px var(--gp-primary-glow); }

.gp-report-card__stat { margin-bottom: var(--space-5); }
.rc-stat-label { display: block; font-size: var(--text-xs); color: var(--gp-faint); font-weight: 600; }
.rc-stat-num { display: block; font-size: clamp(var(--text-3xl),5vw,var(--text-4xl)); font-weight: 900; color: var(--gp-ink); letter-spacing: -.03em; line-height: 1.1; }
.rc-stat-up { font-size: var(--text-xs); font-weight: 700; color: var(--gp-teal); }

/* Çubuk grafik — görünür olunca büyür */
.gp-report-card__chart { display: flex; align-items: flex-end; gap: 8px; height: 130px; margin-bottom: var(--space-5); padding-bottom: var(--space-2); border-bottom: 1px solid var(--gp-line); }
.rc-bar { flex: 1; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 6px; }
.rc-bar__fill { width: 100%; height: 0; border-radius: 7px 7px 3px 3px; background: var(--gp-primary-soft); }
.rc-bar__fill--peak { background: var(--grad-primary); }
.rc-bar__lbl { font-size: 10px; color: var(--gp-faint); font-weight: 600; }
/* görünür olunca animasyon tetiklenir */
.gp-report__visual.is-visible .rc-bar__fill { animation: rc-bar-grow .9s cubic-bezier(.34,1.4,.64,1) forwards; }
@keyframes rc-bar-grow { from { height: 0; } to { height: var(--h); } }

.gp-report-card__lists { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.rc-list-title { display: block; font-size: 11px; font-weight: 700; color: var(--gp-faint); text-transform: uppercase; letter-spacing: .05em; margin-bottom: var(--space-2); }
.rc-row { display: flex; align-items: center; justify-content: space-between; padding: 5px 0; font-size: var(--text-sm); color: var(--gp-text); border-bottom: 1px solid var(--gp-line); }
.rc-row:last-child { border-bottom: none; }
.rc-row strong { color: var(--gp-primary); font-weight: 800; }
.rc-waiter { display: flex; align-items: center; gap: var(--space-2); }
.rc-waiter__av { width: 36px; height: 36px; border-radius: 50%; background: var(--grad-teal); color: #fff; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rc-waiter strong { display: block; font-size: var(--text-sm); font-weight: 800; color: var(--gp-ink); }
.rc-waiter > div span { font-size: var(--text-xs); color: var(--gp-mute); }

@media (max-width: 860px) {
    .gp-report__inner { grid-template-columns: 1fr; text-align: center; }
    .gp-report__list li { justify-content: center; }
    .gp-report__visual { order: -1; }
}
@media (max-width: 420px) {
    .gp-report-card__lists { grid-template-columns: 1fr; }
}

/* ── Yetenek çipleri ──────────────────────────────────────── */
.gp-cap-chips { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; max-width: 900px; margin-inline: auto; }
.gp-cap-chip { display: inline-flex; align-items: center; gap: var(--space-2); padding: .65rem 1.1rem; background: #fff; border: 1px solid var(--gp-line); border-radius: var(--radius-full); font-size: var(--text-sm); font-weight: 700; color: var(--gp-ink); box-shadow: var(--shadow-sm); transition: all var(--transition-fast); }
.gp-cap-chip:hover { border-color: var(--gp-primary); color: var(--gp-primary); transform: translateY(-2px); }
.gp-cap-chip .gp-ico { width: 18px; height: 18px; color: var(--gp-primary); }

/* ── Yetenek bölümü (animasyonlu mini-ekranlar) ───────────── */
.gp-cap__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,6vw,5rem); align-items: center; }
.gp-cap__inner--reverse .gp-cap__text { order: 2; }
.gp-cap__title { font-size: clamp(var(--text-lg),2.2vw,var(--text-2xl)); font-weight: 800; color: var(--gp-ink); letter-spacing: -.02em; line-height: 1.15; margin: var(--space-3) 0 var(--space-4); }
.gp-cap__desc { font-size: var(--text-lg); color: var(--gp-mute); line-height: 1.8; }
.gp-cap__visual { display: flex; justify-content: center; }

/* Mini ekran kartı */
.gp-mini { width: 100%; max-width: 380px; background: #fff; border: 1px solid var(--gp-line); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); overflow: hidden; }
.gp-mini__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--gp-line); font-weight: 800; color: var(--gp-ink); font-size: var(--text-sm); }
.gp-mini__add { font-size: var(--text-xs); font-weight: 800; color: var(--gp-primary); background: var(--gp-primary-soft); padding: 4px 10px; border-radius: var(--radius-full); animation: add-pulse 2s ease-in-out infinite; }
@keyframes add-pulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.06);} }
.gp-mini__badge { font-size: var(--text-xs); font-weight: 800; color: var(--gp-teal); background: var(--gp-teal-soft); padding: 4px 10px; border-radius: var(--radius-full); }
.gp-mini__tabs { display: flex; gap: 4px; padding: var(--space-3) var(--space-4) 0; }
.gp-mini__tabs span { font-size: 11px; font-weight: 700; color: var(--gp-mute); padding: 5px 10px; border-radius: var(--radius-full); background: var(--gp-bg-soft); }
.gp-mini__tabs .is-active { background: var(--grad-primary); color: #fff; }
.gp-mini__rows { padding: var(--space-3) var(--space-4) var(--space-4); display: flex; flex-direction: column; }

/* Ürün satırları — sırayla belir */
.gp-mini-row { display: flex; align-items: center; gap: var(--space-3); padding: .7rem .25rem; border-bottom: 1px solid var(--gp-line); opacity: 0; }
.gp-mini-row:last-child { border-bottom: none; }
.gp-mini-row__dot { width: 9px; height: 9px; border-radius: 50%; background: var(--gp-primary); flex-shrink: 0; }
.gp-mini-row__name { font-size: var(--text-sm); font-weight: 600; color: var(--gp-ink); }
.gp-mini-row__price { margin-left: auto; font-size: var(--text-sm); font-weight: 800; color: var(--gp-primary); }
.gp-cap__visual.is-visible .gp-mini-row { animation: cap-in .5s var(--d) both; }
@keyframes cap-in { from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;} }

/* Toplu fiyat satırları */
.gp-price-rows { padding: var(--space-4); gap: 2px; }
.gp-price-row { display: flex; align-items: center; gap: var(--space-2); padding: .65rem .25rem; border-bottom: 1px solid var(--gp-line); font-size: var(--text-sm); }
.gp-price-row:last-child { border-bottom: none; }
.gp-price-row__name { font-weight: 600; color: var(--gp-ink); }
.gp-price-row__old { margin-left: auto; color: var(--gp-faint); text-decoration: line-through; font-weight: 500; }
.gp-price-row__arrow { color: var(--gp-faint); }
.gp-price-row__new { font-weight: 800; color: var(--gp-teal); opacity: 0; }
.gp-cap__visual.is-visible .gp-price-row__new { animation: price-pop .5s var(--d) both; }
@keyframes price-pop { 0%{opacity:0; transform:translateX(-6px) scale(.8);} 60%{opacity:1; transform:scale(1.15);} 100%{opacity:1; transform:none;} }

/* Rol yetki toggle'ları */
.gp-perm-rows { padding: var(--space-3) var(--space-4) var(--space-4); display: flex; flex-direction: column; }
.gp-perm-row { display: flex; align-items: center; justify-content: space-between; padding: .8rem .25rem; border-bottom: 1px solid var(--gp-line); font-size: var(--text-sm); font-weight: 600; color: var(--gp-ink); }
.gp-perm-row:last-child { border-bottom: none; }
.gp-perm-toggle { width: 44px; height: 25px; border-radius: 999px; background: var(--gp-line-2); position: relative; flex-shrink: 0; }
.gp-perm-toggle i { position: absolute; top: 3px; left: 3px; width: 19px; height: 19px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-sm); }
.gp-cap__visual.is-visible .gp-perm-toggle.is-on { animation: perm-bg .45s var(--d) forwards; }
.gp-cap__visual.is-visible .gp-perm-toggle.is-on i { animation: perm-knob .45s var(--d) forwards; }
@keyframes perm-bg { to { background: linear-gradient(135deg,#34E0C0,#00C896); } }
@keyframes perm-knob { to { transform: translateX(19px); } }

/* Masa grid */
.gp-table-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-2); padding: var(--space-4); }
.gp-table-cell { aspect-ratio: 1.3/1; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); background: var(--gp-primary-soft); color: var(--gp-primary-dark); font-size: var(--text-xs); font-weight: 700; opacity: 0; }
.gp-table-cell--add { background: var(--gp-bg-soft); color: var(--gp-faint); font-size: var(--text-lg); border: 1.5px dashed var(--gp-line-2); }
.gp-cap__visual.is-visible .gp-table-cell { animation: cell-pop .45s var(--d) both; }
@keyframes cell-pop { 0%{opacity:0; transform:scale(.6);} 70%{opacity:1; transform:scale(1.08);} 100%{opacity:1; transform:none;} }

/* Cihaz çipleri (bulut) */
.gp-dev-chips { display: flex; flex-wrap: wrap; gap: 8px; padding: 0 var(--space-4) var(--space-4); }
.gp-dev-chip { font-size: 12px; font-weight: 700; color: var(--gp-ink); background: var(--gp-bg-soft); border: 1px solid var(--gp-line); border-radius: var(--radius-full); padding: 6px 12px; opacity: 0; }
.gp-dev-chip.is-live { color: var(--gp-teal); background: var(--gp-teal-soft); border-color: transparent; }
.gp-cap__visual.is-visible .gp-dev-chip { animation: cap-in .5s var(--d) both; }
.gp-mini__tabs span { cursor: default; }

/* Sınırsız grid */
.gp-inf-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; padding: var(--space-4); }
.gp-inf-item { display: flex; align-items: center; justify-content: space-between; padding: .75rem .9rem; background: var(--gp-bg-soft); border-radius: var(--radius); font-size: var(--text-sm); font-weight: 700; color: var(--gp-ink); opacity: 0; }
.gp-inf-item b { color: var(--gp-purple); font-size: var(--text-xl); line-height: 1; }
.gp-cap__visual.is-visible .gp-inf-item { animation: cell-pop .5s var(--d) both; }

/* Ödeme bölme */
.gp-pay__total { display: flex; align-items: center; justify-content: space-between; padding: var(--space-4) var(--space-4) var(--space-2); font-weight: 800; color: var(--gp-ink); }
.gp-pay__total b { font-size: var(--text-2xl); color: var(--gp-teal); }
.gp-pay__label { padding: 0 var(--space-4) var(--space-3); font-size: var(--text-xs); color: var(--gp-mute); font-weight: 600; }
.gp-pay__split { display: flex; gap: 8px; padding: 0 var(--space-4) var(--space-3); }
.gp-pay__chip { flex: 1; text-align: center; padding: .7rem; background: var(--gp-teal-soft); color: var(--gp-teal); font-weight: 800; border-radius: var(--radius); opacity: 0; }
.gp-cap__visual.is-visible .gp-pay__chip { animation: price-pop .5s var(--d) both; }
.gp-pay__badges { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 var(--space-4) var(--space-4); }
.gp-pay__badge { font-size: 11px; font-weight: 800; color: var(--gp-blue); background: var(--gp-blue-soft); padding: 5px 10px; border-radius: var(--radius-full); }

/* KDS "Sipariş Hazır" butonu */
.gp-kds-ready { display: flex; align-items: center; justify-content: center; gap: 8px; margin: var(--space-2) var(--space-4) var(--space-3); padding: .75rem; border-radius: var(--radius); background: var(--grad-primary); color: #fff; font-size: var(--text-sm); font-weight: 800; box-shadow: var(--shadow-primary); animation: add-pulse 1.8s ease-in-out infinite; }
.gp-kds-ready::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: #fff; }

/* KDS damgası */
.gp-kds__items { padding: var(--space-3) var(--space-4); display: flex; flex-direction: column; }
.gp-kds__stamp { margin: 0 var(--space-4) var(--space-4); text-align: center; font-weight: 900; color: var(--gp-teal); background: var(--gp-teal-soft); border: 2px dashed var(--gp-teal); border-radius: var(--radius); padding: .6rem; letter-spacing: .1em; transform: scale(.6) rotate(-4deg); opacity: 0; }
.gp-cap__visual.is-visible .gp-kds__stamp { animation: kds-stamp .5s .7s both; }
@keyframes kds-stamp { 0%{opacity:0; transform:scale(1.4) rotate(-4deg);} 60%{opacity:1; transform:scale(.92) rotate(-4deg);} 100%{opacity:1; transform:scale(1) rotate(-4deg);} }

@media (max-width: 860px) {
    .gp-cap__inner { grid-template-columns: 1fr; text-align: center; }
    .gp-cap__inner--reverse .gp-cap__text { order: 0; }
    .gp-cap__visual { order: -1; }
}
@media (prefers-reduced-motion: reduce) {
    .gp-dev-chip, .gp-inf-item, .gp-pay__chip, .gp-kds__stamp { opacity: 1 !important; transform: none !important; animation: none !important; }
}

/* ════════════ QR KOD MENÜ SAYFASI ════════════ */
/* Hero düzeni */
.gp-qrhero { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,6vw,4rem); align-items: center; }
.gp-qrhero__visual { display: flex; justify-content: center; }
.gp-qrhero .qr-card { animation: art-float 6s ease-in-out infinite; }
@media (max-width: 860px) { .gp-qrhero { grid-template-columns: 1fr; text-align: center; } .gp-qrhero__text .gp-feat-hero__title, .gp-qrhero__text .gp-feat-hero__desc { text-align: center !important; } .gp-qrhero__text .gp-feat-hero__cta { justify-content: center !important; } }

/* Sipariş toast */
.gp-order-toast { margin: var(--space-2) 0 var(--space-1); text-align: center; font-size: var(--text-sm); font-weight: 800; color: var(--gp-teal); background: var(--gp-teal-soft); border-radius: var(--radius); padding: .6rem; opacity: 0; }
.gp-cap__visual.is-visible .gp-order-toast { animation: cell-pop .5s .7s both; }

/* Garson çağır / hesap iste */
.gp-call-btns { display: flex; gap: var(--space-3); padding: var(--space-4); }
.gp-call-btn { flex: 1; display: flex; flex-direction: column; align-items: center; gap: var(--space-2); padding: var(--space-4); border-radius: var(--radius-lg); font-size: var(--text-sm); font-weight: 800; background: var(--gp-bg-soft); color: var(--gp-ink); border: 1.5px solid var(--gp-line); }
.gp-call-btn .gp-ico { width: 28px; height: 28px; }
.gp-call-btn--bell { color: var(--gp-pink); animation: add-pulse 2s ease-in-out infinite; }
.gp-call-btn--bill { color: var(--gp-primary); }
.gp-cap-notif { display: flex; align-items: center; gap: var(--space-3); margin: 0 var(--space-4) var(--space-4); padding: var(--space-3) var(--space-4); background: #fff; border: 1px solid var(--gp-line); border-left: 3px solid var(--gp-pink); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); opacity: 0; }
.gp-cap__visual.is-visible .gp-cap-notif { animation: cap-in .5s .5s both; }
.gp-cap-notif__ico { width: 34px; height: 34px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); background: var(--gp-pink-soft); color: var(--gp-pink); }
.gp-cap-notif__ico .gp-ico { width: 20px; height: 20px; }
.gp-cap-notif strong { display: block; font-size: var(--text-sm); font-weight: 800; color: var(--gp-ink); }
.gp-cap-notif span { font-size: var(--text-xs); color: var(--gp-mute); }

/* Alerjen & besin */
.gp-prod-desc { padding: var(--space-4) var(--space-4) var(--space-2); font-size: var(--text-sm); color: var(--gp-mute); line-height: 1.6; }
.gp-allergen-row { padding: 0 var(--space-4) var(--space-3); }
.gp-allergen-label { display: block; font-size: 11px; font-weight: 700; color: var(--gp-faint); text-transform: uppercase; letter-spacing: .05em; margin-bottom: var(--space-2); }
.gp-allergen-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.gp-allergen-chip { font-size: 11px; font-weight: 700; color: #B45309; background: #FEF3C7; padding: 4px 10px; border-radius: var(--radius-full); opacity: 0; }
.gp-cap__visual.is-visible .gp-allergen-chip { animation: cap-in .5s var(--d) both; }
.gp-nutri-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; padding: 0 var(--space-4) var(--space-4); }
.gp-nutri-box { text-align: center; padding: .7rem .3rem; background: var(--gp-bg-soft); border-radius: var(--radius); opacity: 0; }
.gp-nutri-box strong { display: block; font-size: var(--text-base); font-weight: 800; color: var(--gp-teal); }
.gp-nutri-box span { font-size: 10px; color: var(--gp-mute); font-weight: 600; }
.gp-cap__visual.is-visible .gp-nutri-box { animation: cell-pop .5s var(--d) both; }

/* Yorum & puan */
.gp-rate { text-align: center; }
.gp-rate__score { display: flex; align-items: baseline; justify-content: center; gap: 4px; padding: var(--space-5) 0 var(--space-2); }
.gp-rate__score .rc-stat-num { font-size: var(--text-5xl); }
.gp-rate__score small { font-size: var(--text-lg); color: var(--gp-faint); font-weight: 700; }
.gp-stars { display: flex; justify-content: center; gap: 6px; font-size: 1.8rem; }
.gp-star { color: var(--gp-line-2); opacity: 0; line-height: 1; }
.gp-cap__visual.is-visible .gp-star { animation: star-pop .45s var(--d) both; }
@keyframes star-pop { 0%{opacity:0; transform:scale(.4);} 60%{opacity:1; transform:scale(1.3);} 100%{opacity:1; transform:scale(1); color:#FFB800;} }
.gp-rate__review { padding: var(--space-4) var(--space-5) var(--space-5); font-size: var(--text-sm); color: var(--gp-text); font-style: italic; }

/* Çoklu dil & dark/light mod */
.gp-lang-flags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: var(--space-5); }
.gp-lang-flag { font-size: var(--text-sm); font-weight: 700; color: var(--gp-ink); background: #fff; border: 1px solid var(--gp-line); padding: 6px 12px; border-radius: var(--radius-full); box-shadow: var(--shadow-sm); }
.gp-theme-card { width: 100%; max-width: 360px; margin-inline: auto; border-radius: var(--radius-xl); border: 1px solid var(--gp-line); box-shadow: var(--shadow-xl); overflow: hidden; background: #fff; color: var(--gp-ink); animation: theme-loop 8s ease-in-out infinite; }
@keyframes theme-loop { 0%,42%{ background:#fff; color:#1E2340; } 50%,92%{ background:#14172a; color:#F2F4F8; } 100%{ background:#fff; color:#1E2340; } }
.gp-theme-card__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-4) var(--space-5); border-bottom: 1px solid; border-color: color-mix(in srgb, currentColor 12%, transparent); }
.gp-theme-card__title { font-weight: 800; }
.gp-theme-toggle { width: 42px; height: 23px; border-radius: 999px; position: relative; background: color-mix(in srgb, currentColor 18%, transparent); }
.gp-theme-toggle i { position: absolute; top: 3px; left: 3px; width: 17px; height: 17px; border-radius: 50%; background: #FFB800; animation: toggle-loop 8s ease-in-out infinite; }
@keyframes toggle-loop { 0%,42%{ transform:translateX(0); background:#FFB800; } 50%,92%{ transform:translateX(19px); background:#fff; } 100%{ transform:translateX(0); background:#FFB800; } }
.gp-theme-card__rows { padding: var(--space-3) var(--space-5) var(--space-4); }
.gp-theme-row { display: flex; align-items: center; justify-content: space-between; padding: .7rem 0; font-size: var(--text-sm); font-weight: 600; border-bottom: 1px solid; border-color: color-mix(in srgb, currentColor 10%, transparent); }
.gp-theme-row:last-child { border-bottom: none; }
.gp-theme-row b { color: var(--gp-primary); }

@media (prefers-reduced-motion: reduce) {
    .gp-order-toast, .gp-cap-notif, .gp-allergen-chip, .gp-nutri-box, .gp-star { opacity: 1 !important; transform: none !important; animation: none !important; }
    .gp-star { color: #FFB800 !important; }
    .gp-theme-card, .gp-theme-toggle i, .gp-call-btn--bell, .gp-qrhero .qr-card { animation: none !important; }
}

/* ════════════ YAZAR KASA (ÖKC) SAYFASI ════════════ */
/* Güvenli işlem akışı */
.gp-flow-card .gp-mini__head { border-bottom: 1px solid var(--gp-line); }
.gp-flow-card .gp-mini__badge { color: var(--gp-primary); background: var(--gp-primary-soft); }
.gp-flow { display: flex; align-items: flex-start; justify-content: space-between; gap: 4px; padding: var(--space-6) var(--space-4) var(--space-4); }
.gp-flow__node { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); width: 60px; flex-shrink: 0; }
.gp-flow__ico { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-md); background: var(--gp-bg-soft); color: var(--gp-mute); transition: all var(--transition); animation: flow-pulse 2.4s ease-in-out infinite; animation-delay: var(--d); }
.gp-flow__ico .gp-ico { width: 26px; height: 26px; }
@keyframes flow-pulse { 0%,100%{ background:var(--gp-bg-soft); color:var(--gp-mute); transform:scale(1);} 18%{ background:var(--gp-primary-soft); color:var(--gp-primary); transform:scale(1.1);} 36%{ background:var(--gp-bg-soft); color:var(--gp-mute); transform:scale(1);} }
.gp-flow__lbl { font-size: 11px; font-weight: 700; color: var(--gp-ink); text-align: center; }
.gp-flow__line { flex: 1; height: 3px; background: var(--gp-line-2); border-radius: 2px; margin-top: 22px; position: relative; overflow: hidden; }
.gp-flow__line::after { content: ''; position: absolute; top: 0; left: -40%; width: 40%; height: 100%; background: linear-gradient(90deg, transparent, var(--gp-primary), transparent); animation: flow-travel 2.4s linear infinite; }
@keyframes flow-travel { from{ left:-40%; } to{ left:100%; } }
.gp-flow-foot { display: flex; flex-wrap: wrap; gap: 8px; padding: var(--space-3) var(--space-4) var(--space-4); border-top: 1px solid var(--gp-line); }
.gp-flow-foot span { font-size: 11px; font-weight: 700; color: var(--gp-primary); background: var(--gp-primary-soft); padding: 4px 10px; border-radius: var(--radius-full); }

/* Cihaz kartları */
.gp-okc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-5); }
.gp-okc-card { position: relative; background: #fff; border: 1px solid var(--gp-line); border-radius: var(--radius-lg); padding: var(--space-6); overflow: hidden; transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition); }
.gp-okc-card::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: var(--c, var(--grad-primary)); transform: scaleX(0); transform-origin: left; transition: transform var(--transition); }
.gp-okc-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: transparent; }
.gp-okc-card:hover::before { transform: scaleX(1); }
.gp-okc-card--blue   { --c: var(--grad-blue); } .gp-okc-card--orange { --c: var(--grad-primary); }
.gp-okc-card--teal   { --c: var(--grad-teal); } .gp-okc-card--purple { --c: var(--grad-purple); }
.gp-okc-card--indigo { --c: linear-gradient(135deg,#7C7CF8,#5B5BF5); } .gp-okc-card--pink { --c: linear-gradient(135deg,#FF7BAC,#FF4D8D); }
.gp-okc-card--green  { --c: var(--grad-teal); }
.gp-okc-card.is-soon { opacity: .85; }

.gp-okc-ribbon { position: absolute; top: 14px; right: 14px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; color: #fff; background: var(--gp-ink); padding: 4px 10px; border-radius: var(--radius-full); }
.gp-okc-ribbon--new { background: var(--grad-primary); }

.gp-okc-card__top { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); }
.gp-okc-card__icon { width: 52px; height: 52px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-md); background: var(--gp-bg-soft); }
.gp-okc-card__icon .gp-ico { width: 28px; height: 28px; }
.gp-okc-brand { display: block; font-size: 11px; font-weight: 700; color: var(--gp-mute); text-transform: uppercase; letter-spacing: .08em; }
.gp-okc-model { font-size: var(--text-lg); font-weight: 800; color: var(--gp-ink); line-height: 1.2; }
.gp-okc-tag { display: inline-flex; align-items: center; gap: 6px; font-size: var(--text-xs); font-weight: 700; color: var(--gp-primary); background: var(--gp-primary-soft); padding: 5px 10px; border-radius: var(--radius-full); margin-bottom: var(--space-4); }
.gp-okc-tag .showcase-check { width: 15px; height: 15px; color: var(--gp-primary); }
.gp-okc-feats { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-5); }
.gp-okc-feats li { position: relative; padding-left: 22px; font-size: var(--text-sm); color: var(--gp-text); font-weight: 500; line-height: 1.5; }
.gp-okc-feats li::before { content: '✓'; position: absolute; left: 0; top: 0; color: var(--gp-primary); font-weight: 900; }
.gp-okc-chips { display: flex; flex-wrap: wrap; gap: 6px; padding-top: var(--space-4); border-top: 1px solid var(--gp-line); }
.gp-okc-chip { font-size: 11px; font-weight: 700; color: var(--gp-ink); background: var(--gp-bg-soft); padding: 4px 10px; border-radius: var(--radius-full); }

@media (max-width: 1024px) { .gp-okc-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px)  { .gp-okc-grid { grid-template-columns: 1fr; } .gp-flow__node { width: 48px; } .gp-flow__ico { width: 40px; height: 40px; } }

@media (prefers-reduced-motion: reduce) {
    .gp-flow__ico { animation: none !important; }
    .gp-flow__line::after { animation: none !important; }
}

/* ════════════ BULUT SENKRONİZASYON ════════════ */
.gp-sync__event { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); margin: var(--space-4); padding: var(--space-3) var(--space-4); background: var(--gp-bg-soft); border-radius: var(--radius); font-size: var(--text-sm); font-weight: 700; color: var(--gp-ink); }
.gp-sync__price del { color: var(--gp-faint); font-weight: 500; }
.gp-sync__price b { color: var(--gp-primary); }
.gp-sync__cloud { display: flex; justify-content: center; padding: var(--space-3) 0 var(--space-4); position: relative; }
.gp-sync__cloud-ic { position: relative; width: 64px; height: 64px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--gp-primary-soft); color: var(--gp-primary); }
.gp-sync__cloud-ic .gp-ico { width: 34px; height: 34px; }
.gp-sync__cloud-ic::before, .gp-sync__cloud-ic::after { content: ''; position: absolute; inset: 0; border-radius: 50%; border: 2px solid var(--gp-primary); opacity: 0; animation: sync-ring 2.6s ease-out infinite; }
.gp-sync__cloud-ic::after { animation-delay: 1.3s; }
@keyframes sync-ring { 0%{ transform: scale(.7); opacity: .5; } 100%{ transform: scale(1.9); opacity: 0; } }
.gp-sync__devices { display: flex; gap: 8px; padding: 0 var(--space-4) var(--space-4); }
.gp-sync-chip { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; padding: .75rem .4rem; border-radius: var(--radius); background: var(--gp-bg-soft); font-size: 11px; font-weight: 700; color: var(--gp-mute); animation: sync-glow 3s ease-in-out infinite; animation-delay: calc(var(--i) * .4s + .8s); }
.gp-sync-chip .gp-ico { width: 24px; height: 24px; }
@keyframes sync-glow { 0%,18%{ background: var(--gp-bg-soft); color: var(--gp-mute); } 32%,55%{ background: var(--gp-primary-soft); color: var(--gp-primary); } 70%,100%{ background: var(--gp-bg-soft); color: var(--gp-mute); } }

@media (prefers-reduced-motion: reduce) {
    .gp-sync__cloud-ic::before, .gp-sync__cloud-ic::after, .gp-sync-chip { animation: none !important; }
    .gp-sync-chip { background: var(--gp-primary-soft); color: var(--gp-primary); }
}

/* ════════════ GOKURYE SAYFASI ════════════ */
/* Sipariş kaynağı etiketleri */
.gp-src-tag { width: 30px; height: 30px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-sm); font-size: 11px; font-weight: 800; color: #fff; }
.gp-src-tag--ys  { background: #FA0050; } .gp-src-tag--gt { background: #5D3EBC; }
.gp-src-tag--ty  { background: #F27A1A; } .gp-src-tag--cid { background: var(--gp-blue); }

/* Harita */
.gp-map { position: relative; height: 320px; overflow: hidden; }
.gp-map__svg { width: 100%; height: 100%; display: block; }
.gp-map__route { stroke-dashoffset: 0; opacity: .25; }
.gp-cap__visual.is-visible .gp-map__route { opacity: 1; stroke-dasharray: 320; stroke-dashoffset: 320; animation: map-draw 1.8s ease forwards .3s; }
@keyframes map-draw { to { stroke-dashoffset: 0; } }
.gp-map__pin { opacity: 0; }
.gp-cap__visual.is-visible .gp-map__pin { animation: map-pin .55s cubic-bezier(.34,1.6,.64,1) forwards 1.5s; }
@keyframes map-pin { 0%{ opacity: 0; transform: translate(170px,50px) scale(.5); } 100%{ opacity: 1; transform: translate(170px,70px) scale(1); } }
.gp-map__me { animation: map-ping 2s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
@keyframes map-ping { 0%,100%{ opacity: 1; } 50%{ opacity: .5; } }
.gp-map__bar { position: absolute; left: 12px; right: 12px; bottom: 12px; display: flex; align-items: center; gap: var(--space-2); background: #fff; border-radius: var(--radius); padding: .6rem .8rem; box-shadow: var(--shadow); font-size: var(--text-xs); font-weight: 700; color: var(--gp-ink); }
.gp-map__bar .gp-ico { width: 20px; height: 20px; color: var(--gp-primary); flex-shrink: 0; }
.gp-map__bar b { margin-left: auto; color: #fff; background: var(--grad-primary); padding: 4px 12px; border-radius: var(--radius-full); }

/* Arama kartı */
.gp-callcard { text-align: center; }
.gp-callcard__num { padding: var(--space-6) 0 var(--space-1); font-size: var(--text-2xl); font-weight: 800; color: var(--gp-ink); letter-spacing: .02em; }
.gp-callcard__num b { color: var(--gp-primary); }
.gp-callcard__hint { font-size: var(--text-xs); color: var(--gp-mute); margin-bottom: var(--space-5); }
.gp-callcard__btn { display: inline-flex; align-items: center; gap: var(--space-2); margin: 0 auto var(--space-6); padding: .9rem 2rem; border-radius: var(--radius-full); font-size: var(--text-base); font-weight: 800; color: #fff; background: var(--grad-primary); box-shadow: var(--shadow-primary); animation: add-pulse 1.8s ease-in-out infinite; }
.gp-callcard__btn .gp-ico { width: 22px; height: 22px; }

@media (prefers-reduced-motion: reduce) {
    .gp-map__route, .gp-map__pin, .gp-map__me, .gp-callcard__btn { animation: none !important; opacity: 1 !important; }
    .gp-map__pin { transform: translate(170px,70px) !important; }
}
@media (prefers-reduced-motion: reduce) {
    .gp-mini-row, .gp-table-cell, .gp-price-row__new { opacity: 1 !important; animation: none !important; }
    .gp-perm-toggle.is-on { background: linear-gradient(135deg,#34E0C0,#00C896) !important; }
    .gp-perm-toggle.is-on i { transform: translateX(19px) !important; }
    .gp-mini__add { animation: none !important; }
}

/* ════════════ AKILLI YÖNETİM MERKEZİ (SMART HUB) ════════════ */

/* Hub Section */
.gp-hub { padding: clamp(3rem, 6vw, 5rem) 0; }

/* Hub Explorer Container */
.gp-hub-explorer {
    position: relative;
    background: #fff;
    border: 1px solid var(--gp-line);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    overflow: hidden;
}

/* Tab Chips */
.gp-hub__chips {
    display: flex;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    border-bottom: 2px solid var(--gp-line);
    background: var(--gp-bg-soft);
}
.gp-hub__chips::-webkit-scrollbar { display: none; }

.hub-chip {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-3);
    font-size: var(--text-sm);
    font-weight: 700;
    color: var(--gp-mute);
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    cursor: pointer;
    transition: all var(--transition);
    position: relative;
    white-space: nowrap;
}
.hub-chip:hover {
    color: var(--gp-ink);
    background: rgba(255,255,255,.6);
}

/* Aktif tab renkleri */
.hub-chip.is-active {
    color: var(--gp-ink);
    background: #fff;
}
.hub-chip--orange.is-active { border-bottom-color: var(--gp-primary); color: var(--gp-primary); }
.hub-chip--pink.is-active   { border-bottom-color: var(--gp-pink);    color: var(--gp-pink); }
.hub-chip--blue.is-active   { border-bottom-color: var(--gp-blue);    color: var(--gp-blue); }
.hub-chip--purple.is-active { border-bottom-color: var(--gp-purple);  color: var(--gp-purple); }

/* Chip icon */
.hub-chip__icon {
    width: 36px; height: 36px;
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--radius);
    background: var(--gp-bg-soft);
    transition: all var(--transition);
}
.hub-chip__icon .gp-ico { width: 20px; height: 20px; }

.hub-chip.is-active .hub-chip__icon { transform: scale(1.08); }
.hub-chip--orange.is-active .hub-chip__icon { background: var(--gp-primary-soft); color: var(--gp-primary); }
.hub-chip--pink.is-active   .hub-chip__icon { background: var(--gp-pink-soft);    color: var(--gp-pink); }
.hub-chip--blue.is-active   .hub-chip__icon { background: var(--gp-blue-soft);    color: var(--gp-blue); }
.hub-chip--purple.is-active .hub-chip__icon { background: var(--gp-purple-soft);  color: var(--gp-purple); }

/* Panel */
.hub-panel {
    display: none;
    grid-template-columns: 1.1fr .9fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
    padding: clamp(2rem, 5vw, 3.5rem);
    animation: hub-fade-in .45s ease both;
}
.hub-panel.is-active { display: grid; }

@keyframes hub-fade-in {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: none; }
}

/* Panel border-top glow */
.hub-panel--orange { border-top: 3px solid var(--gp-primary); }
.hub-panel--pink   { border-top: 3px solid var(--gp-pink); }
.hub-panel--blue   { border-top: 3px solid var(--gp-blue); }
.hub-panel--purple { border-top: 3px solid var(--gp-purple); }

/* Panel text */
.hub-panel__title {
    font-size: clamp(var(--text-lg), 2.2vw, var(--text-2xl));
    font-weight: 800;
    color: var(--gp-ink);
    letter-spacing: -.02em;
    line-height: 1.15;
    margin: var(--space-3) 0 var(--space-4);
}
.hub-panel__desc {
    font-size: var(--text-base);
    color: var(--gp-mute);
    line-height: 1.8;
    margin-bottom: var(--space-5);
}
.hub-panel__list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-bottom: var(--space-6);
}
.hub-panel__list li {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--gp-text);
}
.hub-panel__list .showcase-check {
    width: 22px; height: 22px;
    flex-shrink: 0;
}

/* Panel specific check colors */
.hub-panel--orange .hub-panel__list .showcase-check { color: var(--gp-primary); }
.hub-panel--pink   .hub-panel__list .showcase-check { color: var(--gp-pink); }
.hub-panel--blue   .hub-panel__list .showcase-check { color: var(--gp-blue); }
.hub-panel--purple .hub-panel__list .showcase-check { color: var(--gp-purple); }

.hub-panel__actions {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}

/* Panel visual */
.hub-panel__visual {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
}

/* Paket Servis platform chips */
.hub-platforms {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}
.hub-platform-chip {
    font-size: 11px;
    font-weight: 700;
    color: var(--gp-ink);
    background: var(--gp-bg-soft);
    border: 1px solid var(--gp-line);
    padding: 5px 12px;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-sm);
}

/* QR panel özel */
.hub-qr-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
}
.hub-qr-card {
    animation: art-float 6s ease-in-out infinite;
}
.hub-qr-features {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}
.hub-qr-feat {
    font-size: var(--text-xs);
    font-weight: 700;
    color: var(--gp-purple);
    background: var(--gp-purple-soft);
    padding: 6px 14px;
    border-radius: var(--radius-full);
    transition: transform var(--transition-fast);
}
.hub-qr-feat:hover { transform: translateY(-2px); }

/* Güvenlik panelindeki telefon animasyonlarını tetikle */
.hub-panel.is-active .gp-notif-card {
    opacity: 0;
    transform: translateX(16px) scale(.97);
    animation: notif-pop 9s ease-in-out infinite;
}
.hub-panel.is-active .gp-notif-card--iade  { animation-delay: 0s; }
.hub-panel.is-active .gp-notif-card--ikram { animation-delay: 3s; }
.hub-panel.is-active .gp-notif-card--fiyat { animation-delay: 6s; }

/* Mutfak panelindeki mini-row animasyonları */
.hub-panel.is-active .gp-mini-row {
    opacity: 0;
    animation: cap-in .5s var(--d) both;
}
.hub-panel.is-active .gp-order-toast {
    opacity: 0;
    animation: cell-pop .5s .7s both;
}

/* Phone in hub — fit nicely */
.hub-panel__visual .gp-phone { max-width: 280px; }
.hub-panel__visual .gp-phone__screen { min-height: 380px; }

/* Responsive */
@media (max-width: 960px) {
    .hub-chip__label { font-size: 12px; }
    .hub-chip { padding: var(--space-3) var(--space-2); }
}

@media (max-width: 768px) {
    .gp-hub__chips {
        gap: 0;
        padding: 0;
    }
    .hub-chip {
        flex-direction: column;
        gap: 6px;
        padding: var(--space-3) var(--space-2);
        min-width: 90px;
    }
    .hub-chip__label { font-size: 11px; }
    .hub-chip__icon { width: 32px; height: 32px; }
    .hub-chip__icon .gp-ico { width: 18px; height: 18px; }

    .hub-panel {
        grid-template-columns: 1fr;
        padding: var(--space-5) var(--space-4);
        text-align: center;
    }
    .hub-panel__visual { order: -1; }
    .hub-panel__list li { justify-content: center; }
    .hub-panel__actions { justify-content: center; }
    .hub-panel__visual .gp-phone { max-width: 260px; }
}

@media (max-width: 480px) {
    .hub-chip { min-width: 75px; padding: var(--space-2); }
    .hub-chip__icon { width: 28px; height: 28px; }
    .hub-chip__label { font-size: 10px; }
    .hub-panel { padding: var(--space-4) var(--space-3); }
}

@media (prefers-reduced-motion: reduce) {
    .hub-panel { animation: none !important; }
    .hub-panel.is-active .gp-notif-card { opacity: 1; transform: none; animation: none; }
    .hub-panel.is-active .gp-mini-row { opacity: 1; animation: none; }
    .hub-panel.is-active .gp-order-toast { opacity: 1; animation: none; }
    .hub-qr-card { animation: none !important; }
}
