/* LaFiny e-ticaret — ana stil
   Kaynak: onaylanmış tasarım (lafiny_homepage_mockup.html) birebir taşındı.
   Eklenen: mobil-öncelikli responsive kırılımlar (mockup masaüstü-only idi). */

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --navy:#2B3D6B; --pink:#EE8AA0; --coral:#E2552C; --teal:#2E7D7B;
  --cream:#FBF7F2; --white:#FFFFFF; --sand:#F1E9DD;
  --blush:#FBE4E8; --mint:#DDEEE6; --sky:#E0F0F5; --gold:#E0A93F;
  --text:#2B2A28; --muted:#7A746C; --border:#EBE3D8;
  --fh:'Poppins',sans-serif; --fb:'Inter',sans-serif; --fa:'Dancing Script',cursive;
}

body { font-family:var(--fb); background:var(--cream); color:var(--text); font-size:15px; -webkit-font-smoothing:antialiased; }
img { display:block; max-width:100%; }
a { color:inherit; }

.trust-strip { background:var(--navy); color:rgba(255,255,255,.92); font-size:12px; font-family:var(--fh);
  display:flex; justify-content:center; align-items:center; gap:26px; padding:8px 20px; letter-spacing:.02em; flex-wrap:wrap; }
.trust-strip span { display:flex; align-items:center; gap:7px; }
.trust-strip svg { width:14px; height:14px; stroke:var(--pink); fill:none; stroke-width:1.6; }
.tdot { width:3px; height:3px; background:rgba(255,255,255,.3); border-radius:50%; }

header { background:var(--white); border-bottom:1px solid var(--border); padding:0 56px;
  display:flex; align-items:center; justify-content:space-between; height:76px; position:sticky; top:0; z-index:100; }
.logo-img { height:40px; }
nav { display:flex; gap:30px; }
nav a { font-family:var(--fh); font-size:13.5px; color:var(--text); text-decoration:none; font-weight:500; transition:color .15s; }
nav a:hover { color:var(--coral); }
.header-right { display:flex; align-items:center; gap:16px; }
.icon-btn { background:none; border:none; cursor:pointer; color:var(--navy); padding:0; position:relative; }
.icon-btn svg { width:21px; height:21px; stroke:currentColor; fill:none; stroke-width:1.5; }
.cart-btn { background:var(--navy); color:#fff; border:none; border-radius:24px; padding:10px 20px;
  font-size:13px; font-family:var(--fh); font-weight:500; cursor:pointer; display:flex; align-items:center; gap:8px; text-decoration:none; }
.cart-btn svg { width:16px; height:16px; stroke:#fff; fill:none; stroke-width:1.5; }
.cart-count { background:var(--coral); border-radius:50%; width:18px; height:18px; display:inline-flex;
  align-items:center; justify-content:center; font-size:10px; color:#fff; font-weight:700; }

/* Mobil menü tetikleyici (yalnızca küçük ekran) */
.nav-toggle { display:none; background:none; border:none; cursor:pointer; color:var(--navy); }
.nav-toggle svg { width:24px; height:24px; stroke:currentColor; fill:none; stroke-width:1.6; }

.hero { background:var(--cream); display:grid; grid-template-columns:1fr 1fr; align-items:center; padding:64px 80px 70px; gap:50px; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:11.5px; color:var(--teal);
  font-family:var(--fh); font-weight:600; letter-spacing:.16em; text-transform:uppercase; margin-bottom:24px; }
.hero-eyebrow .ln { width:28px; height:1px; background:var(--teal); }
.hero h1 { font-family:var(--fh); font-size:50px; font-weight:700; color:var(--navy); line-height:1.12; margin-bottom:8px; letter-spacing:-1px; }
.hero-slogan { font-family:var(--fa); font-size:38px; font-weight:600; color:var(--coral); margin-bottom:22px; display:block; }
.hero p { color:#5d564d; font-size:16px; line-height:1.8; max-width:420px; margin-bottom:36px; }
.hero-cta { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.btn-primary { background:var(--coral); color:#fff; border:none; border-radius:30px; padding:16px 36px;
  font-family:var(--fh); font-weight:600; font-size:14.5px; cursor:pointer; box-shadow:0 8px 20px rgba(226,85,44,.25); transition:transform .15s; text-decoration:none; display:inline-block; }
.btn-primary:hover { transform:translateY(-2px); }
.btn-text { background:none; border:none; color:var(--navy); font-family:var(--fh); font-weight:600; font-size:14.5px; cursor:pointer; display:flex; align-items:center; gap:8px; text-decoration:none; }
.btn-text svg { width:18px; height:18px; stroke:var(--navy); fill:none; stroke-width:1.8; }
.hero-visual { position:relative; display:flex; justify-content:center; align-items:center; }
.hero-photo { width:100%; max-width:440px; aspect-ratio:4/4.4; object-fit:cover; border-radius:230px 230px 24px 24px; box-shadow:0 24px 50px rgba(43,61,107,.18); }
.hero-rabbit { position:absolute; height:230px; bottom:-18px; left:-26px; z-index:3; filter:drop-shadow(0 14px 22px rgba(43,61,107,.22)); }
.hero-chip { position:absolute; top:34px; right:-10px; background:#fff; border-radius:14px; padding:12px 16px; box-shadow:0 10px 28px rgba(43,61,107,.14); display:flex; align-items:center; gap:11px; z-index:4; }
.hero-chip .chip-ic { width:34px; height:34px; border-radius:10px; background:var(--mint); display:flex; align-items:center; justify-content:center; }
.hero-chip .chip-ic svg { width:18px; height:18px; stroke:var(--teal); fill:none; stroke-width:1.6; }
.hero-chip strong { font-family:var(--fh); font-size:12.5px; color:var(--navy); display:block; }
.hero-chip span { font-size:11px; color:var(--muted); }

.section { padding:70px 80px; }
.section-head { text-align:center; margin-bottom:42px; }
.section-head .eyebrow { font-family:var(--fh); font-size:11.5px; color:var(--coral); font-weight:600; letter-spacing:.16em; text-transform:uppercase; display:block; margin-bottom:10px; }
.section-head h2 { font-family:var(--fh); font-size:32px; font-weight:700; color:var(--navy); letter-spacing:-.5px; }
.section-head .sub { color:var(--muted); font-size:15px; margin-top:8px; }

.cat-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.cat-card { position:relative; border-radius:18px; overflow:hidden; cursor:pointer; aspect-ratio:4/5; box-shadow:0 4px 16px rgba(43,61,107,.07); transition:transform .25s, box-shadow .25s; text-decoration:none; display:block; }
.cat-card:hover { transform:translateY(-6px); box-shadow:0 16px 32px rgba(43,61,107,.15); }
.cat-card img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.cat-card:hover img { transform:scale(1.06); }
.cat-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(43,61,107,.78) 0%, rgba(43,61,107,.12) 45%, transparent 70%); }
.cat-info { position:absolute; bottom:0; left:0; right:0; padding:20px 18px; }
.cat-info .name { font-family:var(--fh); font-weight:600; font-size:15px; color:#fff; }
.cat-info .count { font-size:11.5px; color:rgba(255,255,255,.8); margin-top:2px; }

.trust-badges { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:34px 80px; display:flex; justify-content:center; gap:64px; flex-wrap:wrap; }
.badge-item { display:flex; align-items:center; gap:13px; }
.badge-icon { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.badge-icon svg { width:21px; height:21px; stroke:var(--navy); fill:none; stroke-width:1.4; stroke-linecap:round; stroke-linejoin:round; }
.badge-text strong { font-family:var(--fh); font-size:13.5px; color:var(--navy); font-weight:600; display:block; }
.badge-text span { font-size:11.5px; color:var(--muted); }

.products-section { padding:70px 80px; }
.product-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.product-card { border-radius:16px; overflow:hidden; background:var(--white); cursor:pointer; transition:transform .2s, box-shadow .2s; position:relative; border:1px solid var(--border); text-decoration:none; display:block; }
.product-card:hover { transform:translateY(-5px); box-shadow:0 14px 30px rgba(43,61,107,.13); }
.product-card:hover .quick-view { opacity:1; transform:translateX(-50%) translateY(0); }
.product-img { aspect-ratio:1; position:relative; overflow:hidden; background:#f3eee7; }
.product-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.product-card:hover .product-img img { transform:scale(1.05); }
.product-img.soldout img { filter:grayscale(.6) opacity(.7); }
.soldout-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(43,61,107,.18); font-family:var(--fh); font-weight:700; font-size:13px; color:#fff; letter-spacing:.05em; }
.wishlist { position:absolute; top:12px; right:12px; width:32px; height:32px; border-radius:50%; background:rgba(255,255,255,.92); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 8px rgba(0,0,0,.08); z-index:2; }
.wishlist svg { width:16px; height:16px; stroke:var(--navy); fill:none; stroke-width:1.6; }
.wishlist:hover svg { stroke:var(--coral); fill:var(--coral); }
.quick-view { position:absolute; bottom:14px; left:50%; transform:translateX(-50%) translateY(8px); background:rgba(255,255,255,.96); color:var(--navy); font-family:var(--fh); font-size:12px; font-weight:600; padding:9px 22px; border-radius:22px; opacity:0; transition:all .22s; white-space:nowrap; box-shadow:0 4px 14px rgba(0,0,0,.1); }
.product-badge { position:absolute; top:13px; left:13px; background:#fff; color:var(--coral); font-family:var(--fh); font-size:10px; font-weight:700; padding:5px 11px; border-radius:20px; letter-spacing:.03em; box-shadow:0 2px 8px rgba(0,0,0,.08); }
.product-badge.teal { color:var(--teal); }
.product-badge.muted { color:var(--muted); }
.product-info { padding:16px 17px 18px; }
.product-series { font-size:10.5px; color:var(--muted); font-family:var(--fh); text-transform:uppercase; letter-spacing:.09em; margin-bottom:5px; }
.product-name { font-family:var(--fh); font-size:14.5px; font-weight:600; color:var(--navy); margin-bottom:6px; line-height:1.3; }
.product-desc { font-size:11.5px; color:var(--muted); margin-bottom:11px; line-height:1.4; }
.product-swatches { display:flex; gap:6px; margin-bottom:13px; }
.swatch { width:16px; height:16px; border-radius:50%; border:1.5px solid rgba(0,0,0,.08); cursor:pointer; }
.swatch.active { box-shadow:0 0 0 2px var(--white), 0 0 0 3.5px var(--navy); }
.product-footer { display:flex; align-items:center; justify-content:space-between; }
.product-price { font-family:var(--fh); font-size:18px; font-weight:700; color:var(--navy); }
.add-btn { background:#fff; color:var(--navy); border:1.5px solid var(--navy); border-radius:22px; padding:8px 16px; font-family:var(--fh); font-size:12px; font-weight:600; cursor:pointer; transition:all .15s; }
.add-btn:hover { background:var(--navy); color:#fff; }
.add-btn:disabled { opacity:.45; cursor:not-allowed; }

/* VIDEO */
.video-section { background:var(--white); padding:70px 80px; }
.video-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.video-card { position:relative; border-radius:18px; overflow:hidden; aspect-ratio:9/16; cursor:pointer; box-shadow:0 6px 20px rgba(43,61,107,.1); background:#000; text-decoration:none; display:block; }
.video-card video { width:100%; height:100%; object-fit:cover; }
.video-card .v-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.55), transparent 45%); pointer-events:none; }
.video-card .v-info { position:absolute; bottom:0; left:0; right:0; padding:16px; pointer-events:none; }
.video-card .v-name { font-family:var(--fh); font-size:13px; font-weight:600; color:#fff; }
.video-card .v-price { font-family:var(--fh); font-size:14px; font-weight:700; color:#fff; margin-top:2px; }
.video-card .v-shop { position:absolute; top:12px; right:12px; background:rgba(255,255,255,.92); color:var(--navy); font-family:var(--fh); font-size:10px; font-weight:600; padding:5px 12px; border-radius:16px; }

/* EDITORIAL */
.editorial { display:grid; grid-template-columns:1fr 1fr; align-items:stretch; background:var(--sand); }
.editorial-img { overflow:hidden; }
.editorial-img img { width:100%; height:100%; object-fit:cover; min-height:460px; }
.editorial-text { padding:70px; display:flex; flex-direction:column; justify-content:center; }
.editorial-text .eyebrow { font-family:var(--fh); font-size:11.5px; color:var(--coral); font-weight:600; letter-spacing:.16em; text-transform:uppercase; margin-bottom:14px; }
.editorial-text h2 { font-family:var(--fh); font-size:34px; font-weight:700; color:var(--navy); line-height:1.25; margin-bottom:18px; letter-spacing:-.4px; }
.editorial-text p { font-size:15.5px; line-height:1.85; color:#5d564d; margin-bottom:28px; max-width:430px; }
.editorial-text .btn-primary { align-self:flex-start; }

/* REVIEWS */
.reviews { background:var(--cream); padding:70px 80px; }
.review-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.review-card { background:#fff; border:1px solid var(--border); border-radius:16px; padding:28px; }
.review-card .stars { display:flex; gap:2px; margin-bottom:14px; }
.review-card .stars svg { width:16px; height:16px; fill:var(--gold); stroke:none; }
.review-card p { font-size:14.5px; line-height:1.7; color:#4a4640; margin-bottom:18px; font-style:italic; }
.review-author { display:flex; align-items:center; gap:11px; }
.review-avatar { width:38px; height:38px; border-radius:50%; background:var(--blush); display:flex; align-items:center; justify-content:center; font-family:var(--fh); font-weight:600; color:var(--coral); font-size:14px; }
.review-author .ra-name { font-family:var(--fh); font-size:13px; font-weight:600; color:var(--navy); }
.review-author .ra-tag { font-size:11px; color:var(--muted); }

/* INSTAGRAM */
.insta { padding:70px 80px; text-align:center; }
.insta-handle { font-family:var(--fh); font-size:18px; font-weight:600; color:var(--navy); margin-bottom:6px; display:flex; align-items:center; justify-content:center; gap:8px; text-decoration:none; }
.insta-handle svg { width:22px; height:22px; stroke:var(--navy); fill:none; stroke-width:1.6; }
.insta-sub { color:var(--muted); font-size:14px; margin-bottom:30px; }
.insta-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
.insta-item { aspect-ratio:1; border-radius:12px; overflow:hidden; position:relative; cursor:pointer; }
.insta-item img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.insta-item:hover img { transform:scale(1.08); }

/* NEWSLETTER */
.newsletter { background:linear-gradient(135deg,var(--blush),var(--mint)); padding:60px 80px; text-align:center; }
.newsletter h2 { font-family:var(--fh); font-size:28px; font-weight:700; color:var(--navy); margin-bottom:10px; }
.newsletter p { color:#5d564d; font-size:15px; margin-bottom:28px; }
.nl-form { display:flex; gap:12px; max-width:480px; margin:0 auto; }
.nl-form input { flex:1; border:1.5px solid rgba(43,61,107,.2); background:rgba(255,255,255,.9); border-radius:30px; padding:14px 22px; font-size:14px; font-family:var(--fb); outline:none; }
.nl-form input:focus { border-color:var(--navy); }
.nl-form button { background:var(--navy); color:#fff; border:none; border-radius:30px; padding:14px 30px; font-family:var(--fh); font-weight:600; font-size:14px; cursor:pointer; white-space:nowrap; }

/* BRAND STORY */
.brand-story { background:linear-gradient(135deg,var(--navy) 0%,#1d2c4d 100%); padding:0 80px; display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; min-height:480px; overflow:hidden; }
.brand-story-text { color:#fff; padding:70px 0; }
.story-tag { font-family:var(--fa); font-size:30px; font-weight:600; color:var(--pink); display:block; margin-bottom:16px; }
.brand-story-text h2 { font-family:var(--fh); font-size:38px; font-weight:700; line-height:1.2; margin-bottom:22px; letter-spacing:-.5px; }
.brand-story-text p { font-size:15px; line-height:1.85; color:rgba(255,255,255,.72); margin-bottom:32px; max-width:440px; }
.btn-outline-white { border:2px solid rgba(255,255,255,.45); color:#fff; background:transparent; border-radius:30px; padding:14px 30px; font-family:var(--fh); font-weight:600; font-size:14px; cursor:pointer; text-decoration:none; display:inline-block; }
.brand-story-visual { display:flex; justify-content:center; align-items:flex-end; height:100%; position:relative; }
.story-rabbit { height:440px; filter:drop-shadow(0 18px 30px rgba(0,0,0,.32)); position:relative; z-index:2; }
.story-glow { position:absolute; bottom:50px; width:360px; height:360px; background:radial-gradient(circle,rgba(238,138,160,.28),transparent 65%); border-radius:50%; }

/* FOOTER */
footer { background:#1a2030; color:rgba(255,255,255,.7); padding:56px 80px 28px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:44px; margin-bottom:36px; }
.footer-logo-chip { display:inline-block; margin-bottom:16px; }
.footer-logo-chip img { height:34px; }
.footer-brand p { font-size:13px; line-height:1.8; max-width:270px; margin-bottom:18px; }
.footer-social { display:flex; gap:12px; }
.footer-social a { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; transition:background .15s; }
.footer-social a:hover { background:var(--coral); }
.footer-social svg { width:17px; height:17px; stroke:#fff; fill:none; stroke-width:1.6; }
.footer-col h4 { font-family:var(--fh); font-size:12px; font-weight:600; color:#fff; margin-bottom:16px; letter-spacing:.08em; text-transform:uppercase; }
.footer-col a { display:block; font-size:13px; color:rgba(255,255,255,.6); text-decoration:none; margin-bottom:10px; transition:color .15s; }
.footer-col a:hover { color:var(--pink); }
.footer-pay { border-top:1px solid rgba(255,255,255,.1); padding-top:22px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.pay-methods { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.pay-methods span { font-size:11.5px; color:rgba(255,255,255,.5); }
.pay-chip { background:rgba(255,255,255,.12); border-radius:6px; padding:5px 10px; font-family:var(--fh); font-size:10px; font-weight:600; color:rgba(255,255,255,.85); letter-spacing:.03em; }
.footer-bottom { font-size:11.5px; color:rgba(255,255,255,.5); text-align:center; margin-top:22px; }

/* WHATSAPP FLOAT */
.wa-float { position:fixed; bottom:26px; right:26px; z-index:200; background:#25D366; color:#fff; border-radius:30px; padding:13px 20px; display:flex; align-items:center; gap:10px; box-shadow:0 8px 24px rgba(37,211,102,.4); cursor:pointer; font-family:var(--fh); font-weight:600; font-size:13.5px; text-decoration:none; }
.wa-float svg { width:22px; height:22px; fill:#fff; }

/* ---------------------------------------------------------------------------
   RESPONSIVE (mobil-öncelikli ek — masaüstü görünüm birebir korunur)
   Kırılımlar: lg 1024 · md 768 · sm 640
--------------------------------------------------------------------------- */
@media (max-width:1024px) {
  header, .section, .products-section, .video-section, .reviews, .insta, .brand-story, footer { padding-left:40px; padding-right:40px; }
  .hero { padding:48px 40px 56px; gap:36px; }
  .hero h1 { font-size:40px; }
  .hero-slogan { font-size:32px; }
  .cat-grid { grid-template-columns:repeat(3,1fr); }
  .product-grid { grid-template-columns:repeat(3,1fr); }
  .video-grid { grid-template-columns:repeat(2,1fr); }
  .insta-grid { grid-template-columns:repeat(4,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .editorial-text, .brand-story-text { padding:48px 0; }
  .brand-story { padding:0 40px; }
  .editorial-text { padding:48px; }
}

@media (max-width:768px) {
  nav { display:none; }
  .nav-toggle { display:inline-flex; }
  header { padding:0 20px; height:64px; }
  .logo-img { height:34px; }
  .trust-strip { gap:14px; font-size:11px; }
  .hero { grid-template-columns:1fr; padding:36px 20px 44px; text-align:center; }
  .hero-eyebrow, .hero-cta { justify-content:center; }
  .hero p { margin-left:auto; margin-right:auto; }
  .hero-visual { order:-1; }
  .hero h1 { font-size:34px; }
  .hero-slogan { font-size:28px; }
  .section, .products-section, .video-section, .reviews, .insta { padding:48px 20px; }
  .section-head h2 { font-size:26px; }
  .cat-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .trust-badges { gap:22px; padding:26px 20px; }
  .badge-item { width:45%; }
  .product-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .editorial { grid-template-columns:1fr; }
  .editorial-img img { min-height:280px; }
  .editorial-text { padding:40px 20px; }
  .review-grid { grid-template-columns:1fr; }
  .insta-grid { grid-template-columns:repeat(3,1fr); }
  .newsletter { padding:48px 20px; }
  .nl-form { flex-direction:column; }
  .brand-story { grid-template-columns:1fr; padding:0 20px; text-align:center; }
  .brand-story-text { padding:48px 0 0; }
  .brand-story-text p { margin-left:auto; margin-right:auto; }
  .story-rabbit { height:320px; }
  .footer-grid { grid-template-columns:1fr; gap:28px; padding:0; }
  footer { padding:44px 20px 24px; }
  .footer-pay { flex-direction:column; align-items:flex-start; }
}

@media (max-width:640px) {
  .video-grid { grid-template-columns:1fr 1fr; }
  .product-price { font-size:16px; }
  .add-btn { padding:7px 12px; }
}

/* Mobil açılır menü paneli */
.mobile-nav { display:none; }
.mobile-nav.open { display:block; }
@media (max-width:768px) {
  .mobile-nav { background:#fff; border-bottom:1px solid var(--border); padding:8px 20px 16px; }
  .mobile-nav a { display:block; padding:12px 0; font-family:var(--fh); font-weight:500; font-size:15px; color:var(--text); text-decoration:none; border-bottom:1px solid var(--border); }
}
