/* ============================================
   Balık Ustalığı Evde — Style System
   Akdeniz Mutfağı: Deniz, Kum, Güneş
   ============================================ */

/* --- CSS Variables --- */
:root {
  --color-bg: #faf8f5;
  --color-bg-alt: #f0ece6;
  --color-surface: #ffffff;
  --color-surface-hover: #f5f2ed;
  --color-surface-border: #e0d8cc;
  --color-ocean: #1a6b7a;
  --color-ocean-light: #2a8d9c;
  --color-ocean-dark: #0e4f5c;
  --color-ocean-glow: rgba(26,107,122,.08);
  --color-sand: #c8a96e;
  --color-sand-light: #dcc28e;
  --color-sand-dark: #a88b4a;
  --color-warm: #d4722a;
  --color-warm-light: #e8934e;
  --color-text: #3d3529;
  --color-text-muted: #8a7e6e;
  --color-text-heading: #2a231a;
  --color-success: #3a8a5c;
  --color-warning: #c48820;
  --color-danger: #c44b4b;
  --color-cream: #fdfbf7;
  --font-main: "Georgia","Palatino Linotype","Book Antiqua",Palatino,serif;
  --font-heading: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --font-mono: "SF Mono","Fira Code","Roboto Mono",monospace;
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 4px rgba(42,35,26,.08);
  --shadow-md: 0 4px 16px rgba(42,35,26,.1);
  --shadow-lg: 0 8px 30px rgba(42,35,26,.14);
  --transition: .25s ease;
  --container-max: 1140px;
  --nav-height: 66px;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:calc(var(--nav-height) + 1rem)}
body{font-family:var(--font-main);background:var(--color-bg);color:var(--color-text);line-height:1.75;font-size:16px;min-height:100vh;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-ocean);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-ocean-dark)}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit}
input,textarea,select{font-family:var(--font-heading);font-size:inherit}

/* --- Skip Link --- */
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--color-ocean);color:#fff;padding:.5rem 1rem;border-radius:var(--radius-sm);z-index:9999;font-weight:600;font-family:var(--font-heading)}
.skip-link:focus{top:.5rem}

/* --- Layout --- */
.container{max-width:var(--container-max);margin:0 auto;padding:0 1.25rem}
.section{padding:4.5rem 0}
.section-dark{background:var(--color-ocean-dark);color:#fff}
.section-dark h2,.section-dark .text-muted{color:#fff}
.section-dark .text-muted{opacity:.75}
.section-dark .chef-card{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12)}
.section-dark .chef-card-title{color:#fff}
.section-dark .chef-card-desc{color:rgba(255,255,255,.7)}
.section-alt{background:var(--color-bg-alt)}

/* --- Grid --- */
.grid{display:grid;gap:1.5rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* --- Navigation --- */
.site-nav{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--color-bg-alt);height:var(--nav-height);display:flex;align-items:center;box-shadow:0 2px 10px rgba(42,35,26,.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--container-max);margin:0 auto;padding:0 1.5rem;gap:1rem}
.nav-logo{font-family:var(--font-heading);font-size:1.2rem;font-weight:800;color:var(--color-text-heading);letter-spacing:.3px;flex-shrink:0;white-space:nowrap}
.nav-logo span{color:var(--color-ocean)}
.nav-links{display:flex;align-items:center;gap:.05rem}

/* Nav top-level links */
.nav-links > a{font-family:var(--font-heading);color:var(--color-text-muted);font-size:.875rem;padding:.42rem .72rem;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);font-weight:500;white-space:nowrap;position:relative}
.nav-links > a::after{content:'';position:absolute;bottom:0;left:.72rem;right:.72rem;height:2px;background:var(--color-ocean);border-radius:2px;transform:scaleX(0);transition:transform .2s ease}
.nav-links > a:hover{color:var(--color-ocean);background:var(--color-ocean-glow)}
.nav-links > a.active{color:var(--color-ocean);font-weight:700}
.nav-links > a.active::after{transform:scaleX(1)}

/* Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-toggle{display:flex;align-items:center;gap:.28rem;background:none;border:none;font-family:var(--font-heading);color:var(--color-text-muted);font-size:.875rem;padding:.42rem .72rem;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);font-weight:500;white-space:nowrap;position:relative;cursor:pointer}
.nav-dropdown-toggle::before{content:'';position:absolute;bottom:0;left:.72rem;right:.72rem;height:2px;background:var(--color-ocean);border-radius:2px;transform:scaleX(0);transition:transform .2s ease}
.nav-dropdown-toggle::after{content:"";border:4px solid transparent;border-top-color:currentColor;margin-top:3px;transition:transform var(--transition);flex-shrink:0}
.nav-dropdown-toggle:hover,.nav-dropdown.open .nav-dropdown-toggle{color:var(--color-ocean);background:var(--color-ocean-glow)}
.nav-dropdown-toggle.active{color:var(--color-ocean);font-weight:700}
.nav-dropdown-toggle.active::before{transform:scaleX(1)}
.nav-dropdown.open .nav-dropdown-toggle::after{transform:rotate(180deg)}

/* Dropdown menu */
.nav-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:240px;background:#fff;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:.4rem 0;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity var(--transition),transform var(--transition),visibility var(--transition);box-shadow:0 8px 24px rgba(42,35,26,.12)}
.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{display:block;padding:.58rem 1.1rem;font-family:var(--font-heading);color:var(--color-text-muted);font-size:.855rem;border-radius:0;transition:background var(--transition),color var(--transition)}
.nav-dropdown-menu a:hover{background:var(--color-surface-hover);color:var(--color-ocean)}
.nav-dropdown-menu a.active{color:var(--color-ocean);font-weight:600;background:var(--color-ocean-glow)}

/* Desktop: hover opens dropdown */
@media(min-width:901px){
  .nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
  .nav-dropdown:hover .nav-dropdown-toggle{color:var(--color-ocean);background:var(--color-ocean-glow)}
  .nav-dropdown:hover .nav-dropdown-toggle::after{transform:rotate(180deg)}
}

/* Hamburger / Close icon */
.nav-hamburger{display:none;align-items:center;justify-content:center;background:none;border:1px solid var(--color-surface-border);color:var(--color-text);padding:.38rem;border-radius:var(--radius-sm);transition:background var(--transition),border-color var(--transition)}
.nav-hamburger:hover{background:var(--color-ocean-glow);border-color:var(--color-ocean)}
.nav-hamburger svg{width:22px;height:22px;display:block}
.nav-hamburger .icon-close{display:none}
.nav-hamburger[aria-expanded="true"] .icon-menu{display:none}
.nav-hamburger[aria-expanded="true"] .icon-close{display:block}
.nav-hamburger[aria-expanded="true"]{background:var(--color-ocean-glow);border-color:var(--color-ocean)}

/* Mobile nav */
@media(max-width:900px){
  .nav-hamburger{display:flex}
  .nav-links{
    position:fixed;top:var(--nav-height);left:0;right:0;width:100%;
    max-height:calc(100svh - var(--nav-height));
    background:#fff;
    flex-direction:column;align-items:stretch;
    padding:.5rem 0 2rem;gap:0;
    opacity:0;visibility:hidden;transform:translateY(-6px);
    transition:opacity .22s ease,transform .22s ease,visibility .22s ease;
    overflow-y:auto;
    border-top:2px solid var(--color-bg-alt);
    box-shadow:0 12px 30px rgba(42,35,26,.1);
    z-index:200
  }
  .nav-links.open{opacity:1;visibility:visible;transform:translateY(0)}

  /* Top-level links in mobile */
  .nav-links > a{
    padding:.9rem 1.4rem;font-size:.97rem;border-radius:0;
    border-bottom:1px solid var(--color-bg-alt);
  }
  .nav-links > a::after{display:none}
  .nav-links > a:last-child{border-bottom:none}
  .nav-links > a.active{background:var(--color-ocean-glow);color:var(--color-ocean);border-left:3px solid var(--color-ocean);padding-left:calc(1.4rem - 3px)}

  /* Dropdown in mobile */
  .nav-dropdown{border-bottom:1px solid var(--color-bg-alt)}
  .nav-dropdown-toggle{
    width:100%;padding:.9rem 1.4rem;font-size:.97rem;
    border-radius:0;justify-content:space-between;
  }
  .nav-dropdown-toggle::before{display:none}
  .nav-dropdown-toggle.active{background:var(--color-ocean-glow);color:var(--color-ocean);border-left:3px solid var(--color-ocean);padding-left:calc(1.4rem - 3px)}
  .nav-dropdown-menu{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:none;border-radius:0;
    background:var(--color-bg-alt);
    display:none;padding:.25rem 0
  }
  .nav-dropdown.open .nav-dropdown-menu{display:block}
  .nav-dropdown-menu a{
    padding:.72rem 1.4rem .72rem 2.4rem;font-size:.9rem;border-radius:0;
    border-bottom:1px solid var(--color-surface-border)
  }
  .nav-dropdown-menu a:last-child{border-bottom:none}
  .nav-dropdown-menu a.active{color:var(--color-ocean);font-weight:600;background:transparent}

  body.nav-open{overflow:hidden}
}

/* --- Hero --- */
.hero{position:relative;background:linear-gradient(170deg, var(--color-ocean-dark) 0%, var(--color-ocean) 60%, var(--color-ocean-light) 100%);padding:5rem 0 4rem;overflow:hidden;color:#fff}
.hero::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.04' d='M0,160L48,170.7C96,181,192,203,288,197.3C384,192,480,160,576,154.7C672,149,768,171,864,186.7C960,203,1056,213,1152,202.7C1248,192,1344,160,1392,144L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'/%3E%3C/svg%3E") no-repeat bottom center;background-size:100% auto;pointer-events:none}
.hero-home{padding:6rem 0 5.5rem;text-align:center}
.hero-content{position:relative;z-index:1}
.hero-tag{display:inline-block;background:rgba(255,255,255,.13);color:#fff;border:1px solid rgba(255,255,255,.2);padding:.3rem .9rem;border-radius:20px;font-family:var(--font-heading);font-size:.82rem;font-weight:600;margin-bottom:1.2rem;letter-spacing:.5px;text-transform:uppercase}
.hero-title{font-family:var(--font-heading);font-size:2.8rem;font-weight:800;color:#fff;line-height:1.18;margin-bottom:1rem}
.hero-title span{color:var(--color-sand-light)}
.hero-subtitle{font-size:1.1rem;color:rgba(255,255,255,.85);max-width:620px;margin-bottom:2.2rem}
.hero-home .hero-subtitle{margin-left:auto;margin-right:auto}
.hero .img-rounded{margin:2.5rem auto 0;max-width:800px;border-radius:var(--radius-lg);box-shadow:0 12px 40px rgba(0,0,0,.3);border:3px solid rgba(255,255,255,.15)}
@media(max-width:600px){.hero-title{font-size:1.9rem}.hero-home{padding:3.5rem 0 3rem}}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.5rem;border-radius:var(--radius-md);font-family:var(--font-heading);font-size:.95rem;font-weight:600;border:none;transition:all var(--transition);text-decoration:none}
.btn-primary{background:var(--color-sand);color:#fff;box-shadow:0 2px 8px rgba(200,169,110,.3)}
.btn-primary:hover{background:var(--color-sand-dark);color:#fff;box-shadow:0 4px 16px rgba(200,169,110,.4);transform:translateY(-1px)}
.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-surface-border)}
.btn-secondary:hover{background:var(--color-surface-hover);color:var(--color-ocean-dark);border-color:var(--color-ocean)}
.btn-outline{background:transparent;color:var(--color-ocean);border:2px solid var(--color-ocean);padding:.6rem 1.3rem}
.btn-outline:hover{background:var(--color-ocean);color:#fff}
.hero .btn-primary{background:var(--color-sand);color:#fff}
.hero .btn-primary:hover{background:var(--color-sand-dark);color:#fff}

/* --- Breadcrumb --- */
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;padding:1rem 1.25rem;font-family:var(--font-heading);font-size:.85rem;color:var(--color-text-muted);max-width:var(--container-max);margin-left:auto;margin-right:auto}
.breadcrumb a{color:var(--color-text-muted)}
.breadcrumb a:hover{color:var(--color-ocean)}
.breadcrumb-separator{color:var(--color-surface-border);user-select:none}
.breadcrumb .active{color:var(--color-text)}

/* --- Page Header --- */
.page-header{padding:3.5rem 0 2.5rem;background:linear-gradient(170deg, var(--color-ocean-dark) 0%, var(--color-ocean) 100%);color:#fff;border-bottom:none}
.page-header-title{font-family:var(--font-heading);font-size:2.2rem;font-weight:800;color:#fff;margin-bottom:.6rem}
.page-header-desc{font-size:1.05rem;color:rgba(255,255,255,.8);max-width:700px}
.page-header .breadcrumb{color:rgba(255,255,255,.6)}
.page-header .breadcrumb a{color:rgba(255,255,255,.6)}
.page-header .breadcrumb a:hover{color:#fff}
.page-header .breadcrumb .active{color:rgba(255,255,255,.9)}
.page-header .breadcrumb-separator{color:rgba(255,255,255,.3)}
@media(max-width:600px){.page-header{padding:2.5rem 0 1.8rem}.page-header-title{font-size:1.6rem}}

/* --- Chef Cards --- */
.chef-card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:1.8rem 1.5rem;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;overflow:hidden;text-decoration:none;color:inherit}
.chef-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-ocean),var(--color-sand));opacity:0;transition:opacity var(--transition)}
.chef-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-ocean-light)}
.chef-card:hover::before{opacity:1}
.chef-card-number{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--color-ocean-glow);color:var(--color-ocean);border-radius:50%;font-family:var(--font-heading);font-size:.88rem;font-weight:700;margin-bottom:1rem;border:2px solid rgba(26,107,122,.15)}
.chef-card-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--color-text-heading);margin-bottom:.6rem}
.chef-card-title a{color:inherit}
.chef-card-title a:hover{color:var(--color-ocean)}
.chef-card-desc{font-size:.92rem;color:var(--color-text-muted);line-height:1.65}
.chef-card-img{width:100%;height:190px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:1rem}

/* --- Article Content --- */
.article-content{max-width:800px;padding:2.5rem 0;margin:0 auto}
.article-content h2{font-family:var(--font-heading);font-size:1.55rem;font-weight:700;color:var(--color-text-heading);margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-sand-light)}
.article-content h3{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;color:var(--color-ocean-dark);margin:2rem 0 .8rem}
.article-content p{margin-bottom:1.2rem;color:var(--color-text)}
.article-content ul,.article-content ol{margin:1rem 0 1.5rem 0;padding:0}
.article-content ul{list-style:none}
.article-content ul li{padding-left:1.7rem;position:relative;margin-bottom:.5rem;color:var(--color-text)}
.article-content ul li::before{content:'🪝';position:absolute;left:0;top:.05em;font-size:.82em;line-height:1.6;display:inline-block;transform:scaleX(-1)}
.article-content ol{list-style:decimal;padding-left:1.5rem}
.article-content li{margin-bottom:.5rem;color:var(--color-text)}
.article-content strong{color:var(--color-text-heading);font-weight:600}
.article-content blockquote{border-left:4px solid var(--color-sand);padding:.8rem 1.2rem;background:var(--color-bg-alt);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:1.5rem 0;color:var(--color-text-muted);font-style:italic}
.article-content figure{margin:2rem 0}
.article-content figure img{border-radius:var(--radius-md);border:1px solid var(--color-surface-border)}
.article-content figcaption{font-family:var(--font-heading);font-size:.85rem;color:var(--color-text-muted);margin-top:.5rem;text-align:center}

/* --- Tip / Warning / Info Boxes --- */
.tip-box,.warning-box,.info-box{padding:1.3rem 1.5rem;border-radius:var(--radius-md);margin:1.5rem 0;border-left:4px solid;background:var(--color-surface)}
.tip-box{border-color:var(--color-ocean);background:rgba(26,107,122,.04)}
.warning-box{border-color:var(--color-warm);background:rgba(212,114,42,.04)}
.info-box{border-color:var(--color-success);background:rgba(58,138,92,.04)}
.tip-box-title,.warning-box-title,.info-box-title{font-family:var(--font-heading);font-size:.88rem;font-weight:700;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}
.tip-box .tip-box-title{color:var(--color-ocean)}
.warning-box .warning-box-title{color:var(--color-warm)}
.info-box .info-box-title{color:var(--color-success)}
.tip-box p,.warning-box p,.info-box p{margin:0;font-size:.92rem;color:var(--color-text-muted);line-height:1.65}

/* --- Recipe Block --- */
.recipe-block{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:2rem;margin:2rem 0;box-shadow:var(--shadow-sm)}
.recipe-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--color-bg-alt)}
.recipe-header h3{font-family:var(--font-heading);font-size:1.4rem;color:var(--color-text-heading);font-weight:700;margin-bottom:.4rem}
.recipe-meta{display:flex;flex-wrap:wrap;gap:1rem;font-family:var(--font-heading);font-size:.85rem;color:var(--color-text-muted)}
.recipe-meta span{display:flex;align-items:center;gap:.3rem}
.recipe-body{display:grid;grid-template-columns:1fr 1.6fr;gap:2rem}
@media(max-width:700px){.recipe-body{grid-template-columns:1fr}}
.recipe-ingredients h4,.recipe-steps h4{font-family:var(--font-heading);font-size:.95rem;font-weight:700;color:var(--color-ocean-dark);margin-bottom:.8rem;text-transform:uppercase;letter-spacing:.4px}
.recipe-ingredients ul{list-style:none;padding:0}
.recipe-ingredients li{padding:.45rem 0;border-bottom:1px solid var(--color-bg-alt);font-size:.92rem;color:var(--color-text)}
.recipe-ingredients li:last-child{border:none}
.recipe-steps ol{list-style:none;padding:0;counter-reset:recipe-step}
.recipe-steps li{counter-increment:recipe-step;padding:.6rem 0 .6rem 2.2rem;position:relative;font-size:.92rem;color:var(--color-text)}
.recipe-steps li::before{content:counter(recipe-step);position:absolute;left:0;top:.6rem;width:24px;height:24px;background:var(--color-ocean-glow);color:var(--color-ocean);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:.78rem;font-weight:700}

/* --- Step List --- */
.step-list{counter-reset:step-counter;padding:1rem 0}
.step-item{display:flex;gap:1.2rem;margin-bottom:1.5rem;align-items:flex-start}
.step-number{flex-shrink:0;width:44px;height:44px;background:var(--color-ocean);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:1rem;box-shadow:0 2px 8px rgba(26,107,122,.25)}
.step-content h4{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:var(--color-text-heading);margin-bottom:.3rem}
.step-content p{color:var(--color-text-muted);font-size:.92rem}

/* --- Data Table --- */
.data-table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem}
.data-table th,.data-table td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--color-bg-alt)}
.data-table th{background:var(--color-ocean-dark);color:#fff;font-family:var(--font-heading);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.3px}
.data-table td{color:var(--color-text);background:var(--color-surface)}
.data-table tr:hover td{background:var(--color-surface-hover)}
.table-wrap{overflow-x:auto;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}

/* --- Tags --- */
.tag{display:inline-block;padding:.22rem .65rem;border-radius:20px;font-family:var(--font-heading);font-size:.78rem;font-weight:600;letter-spacing:.3px}
.tag-blue{background:var(--color-ocean-glow);color:var(--color-ocean);border:1px solid rgba(26,107,122,.2)}
.tag-green{background:rgba(58,138,92,.08);color:var(--color-success);border:1px solid rgba(58,138,92,.2)}
.tag-orange{background:rgba(212,114,42,.08);color:var(--color-warm);border:1px solid rgba(212,114,42,.2)}

/* --- FAQ --- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--color-surface-border);border-radius:var(--radius-md);margin-bottom:.75rem;overflow:hidden;background:var(--color-surface);box-shadow:var(--shadow-sm)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;background:none;border:none;font-family:var(--font-heading);color:var(--color-text-heading);font-size:1rem;font-weight:600;text-align:left;cursor:pointer;transition:background var(--transition)}
.faq-question:hover{background:var(--color-surface-hover)}
.faq-question::after{content:"+";font-size:1.3rem;color:var(--color-ocean);transition:transform var(--transition);flex-shrink:0;margin-left:1rem}
.faq-item.open .faq-question::after{content:"\2212"}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.faq-item.open .faq-answer{max-height:600px}
.faq-answer-inner{padding:0 1.3rem 1.2rem;color:var(--color-text);font-size:.92rem;line-height:1.75}

/* --- Contact Form --- */
.contact-form-card{max-width:680px;margin:0 auto;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:2.5rem 2.5rem 2rem;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
.contact-form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-ocean),var(--color-sand))}
.contact-form-card h2{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--color-text-heading);margin-bottom:.4rem}
.contact-form-card>p{color:var(--color-text-muted);font-size:.92rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-bg-alt);padding-bottom:1.2rem}
@media(max-width:600px){.contact-form-card{padding:1.5rem 1.25rem 1.25rem}}
.contact-form{max-width:600px;margin:0 auto}
/* Contact info grid below form */
.contact-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:680px;margin:2rem auto 0}
@media(max-width:600px){.contact-info-grid{grid-template-columns:1fr}}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-family:var(--font-heading);font-size:.88rem;font-weight:600;color:var(--color-text);margin-bottom:.4rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition),box-shadow var(--transition)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-ocean);box-shadow:0 0 0 3px var(--color-ocean-glow)}
.form-group textarea{resize:vertical;min-height:120px}
.form-msg{padding:.8rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-family:var(--font-heading);font-size:.9rem;display:none}
.form-msg.success{display:block;background:rgba(58,138,92,.08);color:var(--color-success);border:1px solid rgba(58,138,92,.2)}
.form-msg.error{display:block;background:rgba(196,75,75,.08);color:var(--color-danger);border:1px solid rgba(196,75,75,.2)}
.hp-field{position:absolute;left:-9999px;top:-9999px;opacity:0;height:0;width:0;overflow:hidden}

/* --- Related Links --- */
.related-section{padding:3rem 0;border-top:2px solid var(--color-bg-alt)}
.related-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--color-text-heading);margin-bottom:1.2rem}
.related-links{display:flex;flex-wrap:wrap;gap:.8rem}
.related-link-item{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-family:var(--font-heading);font-size:.88rem;transition:all var(--transition)}
.related-link-item:hover{background:var(--color-ocean-glow);border-color:var(--color-ocean);color:var(--color-ocean-dark)}
.related-link-item::before{content:"\2192";color:var(--color-ocean);font-size:.8rem}

/* --- Footer --- */
.site-footer{background:var(--color-ocean-dark);color:rgba(255,255,255,.8);padding:3.5rem 0 0}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
@media(max-width:800px){.footer-grid{grid-template-columns:1fr 1fr;gap:1.5rem}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-col h4{font-family:var(--font-heading);font-size:.9rem;font-weight:700;color:var(--color-sand-light);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}
.footer-col p{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.6}
.footer-col a{display:block;font-size:.88rem;color:rgba(255,255,255,.55);padding:.25rem 0;transition:color var(--transition)}
.footer-col a:hover{color:var(--color-sand-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.2rem 0;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;font-family:var(--font-heading);font-size:.82rem;color:rgba(255,255,255,.4)}
.footer-legal a{color:rgba(255,255,255,.4);margin-left:1rem}
.footer-legal a:hover{color:var(--color-sand-light)}

/* --- Legal Pages --- */
.legal-content{max-width:800px;padding:2.5rem 0;margin:0 auto}
.legal-content h2{font-family:var(--font-heading);font-size:1.35rem;font-weight:700;color:var(--color-text-heading);margin:2rem 0 .8rem}
.legal-content h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--color-ocean-dark);margin:1.5rem 0 .6rem}
.legal-content p{margin-bottom:1rem;font-size:.92rem}
.legal-content ul{list-style:none;margin:1rem 0 1.5rem 0;padding:0}
.legal-content ul li{padding-left:1.7rem;position:relative;margin-bottom:.4rem;font-size:.92rem}
.legal-content ul li::before{content:'🪝';position:absolute;left:0;top:.05em;font-size:.82em;line-height:1.6;display:inline-block;transform:scaleX(-1)}
.legal-content li{margin-bottom:.4rem;font-size:.92rem}

/* --- Cookie Banner --- */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--color-surface);border-top:1px solid var(--color-surface-border);padding:1.2rem 0;transform:translateY(100%);transition:transform .4s ease;box-shadow:0 -4px 20px rgba(0,0,0,.1)}
.cookie-banner.visible{transform:translateY(0)}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cookie-text{flex:1;font-size:.88rem;color:var(--color-text-muted);min-width:280px}
.cookie-text a{color:var(--color-ocean);text-decoration:underline}
.cookie-buttons{display:flex;gap:.6rem;flex-shrink:0;flex-wrap:wrap}
.cookie-btn{font-family:var(--font-heading);padding:.55rem 1.1rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;border:1px solid var(--color-surface-border);background:var(--color-surface-hover);color:var(--color-text);transition:all var(--transition)}
.cookie-btn:hover{border-color:var(--color-ocean);color:var(--color-ocean-dark)}
.cookie-btn-accept{background:var(--color-ocean);border-color:var(--color-ocean);color:#fff}
.cookie-btn-accept:hover{background:var(--color-ocean-dark)}

/* Cookie Modal */
.cookie-modal-overlay{position:fixed;inset:0;z-index:250;background:rgba(0,0,0,.4);display:none;align-items:center;justify-content:center;padding:1rem}
.cookie-modal-overlay.visible{display:flex}
.cookie-modal{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);max-width:500px;width:100%;padding:2rem;box-shadow:var(--shadow-lg);max-height:80vh;overflow-y:auto}
.cookie-modal h3{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-text-heading);margin-bottom:1.2rem}
.cookie-option{display:flex;align-items:center;justify-content:space-between;padding:.8rem 0;border-bottom:1px solid var(--color-bg-alt)}
.cookie-option:last-of-type{border:none}
.cookie-option-label{font-family:var(--font-heading);font-size:.9rem;color:var(--color-text)}
.cookie-option-label small{display:block;font-size:.8rem;color:var(--color-text-muted);margin-top:.15rem}

/* Toggle switch */
.toggle{position:relative;width:44px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;inset:0;background:var(--color-surface-border);border-radius:24px;cursor:pointer;transition:background var(--transition)}
.toggle-slider::before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform var(--transition)}
.toggle input:checked+.toggle-slider{background:var(--color-ocean)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px)}
.toggle input:disabled+.toggle-slider{opacity:.5;cursor:default}
.cookie-modal-buttons{display:flex;gap:.6rem;margin-top:1.5rem;justify-content:flex-end}

/* --- Misc --- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading)}
.text-center{text-align:center}
.text-muted{color:var(--color-text-muted)}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Divider */
.section-divider{height:2px;background:linear-gradient(90deg,transparent,var(--color-sand-light) 30%,var(--color-ocean-light) 70%,transparent);margin:0}

/* Image grid */
.img-rounded{border-radius:var(--radius-md);border:1px solid var(--color-surface-border)}

/* Stats row */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;padding:.25rem 0}
.stat-item{
  text-align:center;background:var(--color-surface);
  border:1px solid var(--color-surface-border);
  border-radius:var(--radius-lg);padding:1.6rem 1rem;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--transition),box-shadow var(--transition)
}
.stat-item::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-ocean),var(--color-sand))}
.stat-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat-value{font-family:var(--font-heading);font-size:2.4rem;font-weight:800;color:var(--color-ocean);line-height:1;display:block}
.stat-label{font-family:var(--font-heading);font-size:.82rem;color:var(--color-text-muted);margin-top:.5rem;font-weight:500;display:block;letter-spacing:.2px}
@media(max-width:700px){.stats-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:380px){.stats-row{grid-template-columns:1fr}}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeInUp .5s ease both}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* Focus styles */
:focus-visible{outline:2px solid var(--color-ocean);outline-offset:2px;border-radius:2px}
button:focus-visible,a:focus-visible,.toggle input:focus-visible+.toggle-slider{outline:2px solid var(--color-ocean);outline-offset:2px}
