/* ============================================================
   Foto Is Akisi — styles.css
   Darkroom + Teknik Panel Atmosferi
   ============================================================ */

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg-primary:#141418;
  --bg-secondary:#1c1c22;
  --bg-panel:#242430;
  --bg-card:#2a2a36;
  --bg-hover:#30303e;
  --border:#333340;
  --border-hover:#48485a;
  --text-primary:#eae8e3;
  --text-body:#c4c2bb;
  --text-muted:#8a887f;
  --accent:#c9a55a;
  --accent-hover:#dbb76c;
  --accent-dim:#8a7a42;
  --accent-glow:rgba(201,165,90,0.10);
  --red:#c45c54;
  --green:#5ea85e;
  --font:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'Cascadia Code','Fira Code',Consolas,monospace;
  --max-w:1100px;
  --r:8px;
  --speed:0.22s;
  --header-h:60px;
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* --- Base --- */
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font);
  background:var(--bg-primary);
  color:var(--text-primary);
  line-height:1.75;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* --- Skip Link --- */
.skip-link{
  position:absolute;top:-200%;left:16px;
  background:var(--accent);color:var(--bg-primary);
  padding:10px 20px;border-radius:var(--r);
  z-index:99999;font-weight:700;text-decoration:none;
  font-size:0.9rem;
}
.skip-link:focus{top:16px}

/* --- Links --- */
a{color:var(--accent);text-decoration:none;transition:color var(--speed)}
a:hover{color:var(--accent-hover)}
a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}

/* --- Typography --- */
h1,h2,h3,h4,h5{color:var(--text-primary);line-height:1.35;font-weight:700}
h1{font-size:1.9rem;margin-bottom:1.2rem;letter-spacing:-0.02em}
h2{font-size:1.35rem;margin-bottom:0.8rem;padding-bottom:0.6rem;border-bottom:1px solid var(--border);margin-top:2.4rem}
h3{font-size:1.12rem;margin-bottom:0.5rem;margin-top:1.8rem;color:var(--accent)}
h4{font-size:1rem;margin-bottom:0.4rem}
p{margin-bottom:1.1rem;color:var(--text-body)}
strong,b{color:var(--text-primary)}
ul,ol{margin:0 0 1.2rem 1.6rem;color:var(--text-body)}
li{margin-bottom:0.4rem}
li::marker{color:var(--accent-dim)}
blockquote{
  border-left:3px solid var(--accent-dim);
  padding:12px 20px;margin:1.5rem 0;
  background:var(--bg-card);border-radius:0 var(--r) var(--r) 0;
}
blockquote p{margin-bottom:0;color:var(--text-muted);font-style:italic}

/* --- Layout --- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 20px}
/* Inside main, main already centers & pads — avoid double padding */
main .container{max-width:none;padding:0}

/* ==========================================================
   HEADER
   ========================================================== */
.site-header{
  background:var(--bg-secondary);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:500;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
/* Support both .header-inner and .header-container */
.header-inner,.header-container{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;height:var(--header-h);
  max-width:var(--max-w);margin:0 auto;
}
/* Logo — support both .site-logo and .logo */
.site-logo,.logo{
  font-size:1.1rem;font-weight:800;color:var(--text-primary);
  text-decoration:none;letter-spacing:0.3px;
  white-space:nowrap;flex-shrink:0;
}
.site-logo span,.logo span{
  color:var(--accent);
  transition:color var(--speed);
}
.site-logo:hover,.logo:hover{color:var(--text-primary)}
.site-logo:hover span,.logo:hover span{
  color:var(--accent-hover);
  text-shadow:0 0 12px rgba(201,165,90,0.3);
}

/* --- Nav Toggle (hamburger / X) --- */
.nav-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  width:36px;height:36px;position:relative;
  flex-shrink:0;padding:0;
  /* align icon vertically with logo */
  align-self:center;
}
/* Hide all inner elements — we draw lines with ::before/::after on the button */
.nav-toggle span,
.nav-toggle .nav-toggle-bar,
.nav-toggle .hamburger{
  display:none;
}
/* Draw 3 lines via pseudo-elements + box-shadow trick */
.nav-toggle::before,
.nav-toggle::after{
  content:'';position:absolute;left:7px;
  width:22px;height:2px;background:var(--text-primary);
  border-radius:2px;transition:transform 0.3s ease,top 0.3s ease;
}
.nav-toggle::before{top:12px}
.nav-toggle::after{top:22px}
/* Middle line via box-shadow on ::before */
.nav-toggle::before{
  box-shadow:0 5px 0 var(--text-primary);
}
/* X state */
.nav-toggle.open::before{
  top:17px;transform:rotate(45deg);
  box-shadow:none;
}
.nav-toggle.open::after{
  top:17px;transform:rotate(-45deg);
}

/* --- Main Nav --- */
.main-nav{display:flex;align-items:center}
.main-nav>.nav-list,
.main-nav>ul{
  display:flex;list-style:none;gap:2px;margin:0;padding:0;
  align-items:center;flex-wrap:wrap;
}
/* Ensure ALL nested ULs inside nav also reset list-style */
.main-nav ul{list-style:none;margin:0;padding:0}

/* Nav links — support <a> and <button> */
.main-nav a,
.main-nav button.dropdown-toggle{
  display:block;padding:8px 14px;
  font-size:0.82rem;font-weight:500;
  color:var(--text-muted);border-radius:var(--r);
  transition:background var(--speed),color var(--speed);
  background:none;border:none;cursor:pointer;
  font-family:var(--font);white-space:nowrap;
}
.main-nav a:hover,
.main-nav button.dropdown-toggle:hover,
.main-nav a.active,
.main-nav button.active{
  background:var(--bg-panel);color:var(--accent);
}

/* Nav items */
.nav-item{list-style:none}
.nav-link{
  display:block;padding:8px 14px;
  font-size:0.82rem;font-weight:500;
  color:var(--text-muted);border-radius:var(--r);
  transition:background var(--speed),color var(--speed);
  text-decoration:none;
}
.nav-link:hover,.nav-link.active{
  background:var(--bg-panel);color:var(--accent);
}

/* --- Dropdowns (all variants) --- */
.nav-dropdown,.has-dropdown{position:relative}
.nav-dropdown>a::after,
.has-dropdown>a::after,
.has-dropdown>button::after{
  content:'';display:inline-block;
  width:0;height:0;margin-left:6px;vertical-align:middle;
  border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:4px solid currentColor;
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
/* Rotate arrow on hover (desktop) and open (mobile) */
.nav-dropdown:hover>a::after,
.has-dropdown:hover>a::after,
.has-dropdown:hover>button::after,
.nav-dropdown.open>a::after,
.has-dropdown.open>a::after,
.has-dropdown.open>button::after{
  transform:rotate(180deg);
}
.nav-dropdown-menu,
.dropdown-menu,
ul.dropdown,
.main-nav .dropdown,
.main-nav .dropdown-menu,
.main-nav .nav-dropdown-menu{
  position:absolute;top:calc(100% + 4px);left:0;
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);min-width:230px;padding:8px 0;
  z-index:600;box-shadow:0 12px 40px rgba(0,0,0,0.5);
  list-style:none;margin:0;
  /* Hidden state */
  opacity:0;visibility:hidden;
  transform:translateY(-10px);
  pointer-events:none;
  /* Close: fade out + slide up */
  transition:opacity 0.35s cubic-bezier(0.4,0,0.2,1),
             transform 0.35s cubic-bezier(0.4,0,0.2,1),
             visibility 0s linear 0.35s;
}
.nav-dropdown:hover>.nav-dropdown-menu,
.has-dropdown:hover>.dropdown-menu,
.has-dropdown:hover>.dropdown{
  opacity:1;visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
  /* Open: fade in + slide down */
  transition:opacity 0.35s cubic-bezier(0.4,0,0.2,1),
             transform 0.35s cubic-bezier(0.4,0,0.2,1),
             visibility 0s linear 0s;
}

.nav-dropdown-menu a,.dropdown-menu a,.dropdown a{
  display:block;padding:9px 18px;border-radius:0;
  font-size:0.82rem;color:var(--text-body);
}
.nav-dropdown-menu a:hover,.dropdown-menu a:hover,.dropdown a:hover,
.nav-dropdown-menu a.active,.dropdown-menu a.active,.dropdown a.active{
  background:var(--accent-glow);color:var(--accent);
}

/* --- Mobile Nav --- */
@media(max-width:960px){
  .nav-toggle{display:flex;align-items:center;justify-content:center}
  .main-nav{
    display:none;position:absolute;
    top:var(--header-h);left:0;right:0;
    background:var(--bg-secondary);
    border-bottom:1px solid var(--border);
    padding:12px 0 16px;
    box-shadow:0 12px 32px rgba(0,0,0,0.4);
    max-height:calc(100vh - var(--header-h));
    overflow-y:auto;
  }
  .main-nav.open{display:block}
  .main-nav>.nav-list,.main-nav>ul{
    flex-direction:column;gap:0;width:100%;
  }
  /* Top-level nav items */
  .main-nav .nav-item,
  .main-nav>.nav-list>li,
  .main-nav>ul>li{
    border-bottom:1px solid var(--border);
  }
  .main-nav .nav-item:last-child,
  .main-nav>.nav-list>li:last-child,
  .main-nav>ul>li:last-child{border-bottom:none}

  .main-nav a,
  .main-nav button.dropdown-toggle{
    padding:14px 20px;font-size:0.92rem;width:100%;text-align:left;
    border-radius:0;color:var(--text-body);
    background:none;
  }
  .main-nav a:hover,
  .main-nav button.dropdown-toggle:hover{
    background:none;color:var(--accent);
  }
  .main-nav a.active{
    background:none;color:var(--accent);
  }

  /* --- Mobile dropdowns: smooth slide --- */
  .main-nav .nav-dropdown-menu,
  .main-nav .dropdown-menu,
  .main-nav .dropdown,
  .main-nav ul.dropdown{
    position:static !important;
    box-shadow:none;border:none;
    padding:0;margin:0;
    background:none;min-width:0;
    border-radius:0;
    overflow:hidden;
    opacity:1;visibility:visible;
    transform:none;pointer-events:auto;
    /* Closed */
    max-height:0;
    transition:max-height 0.4s cubic-bezier(0.4,0,0.2,1);
  }
  /* --- Open state --- */
  .nav-dropdown.open>.nav-dropdown-menu,
  .has-dropdown.open>.dropdown-menu,
  .has-dropdown.open>.dropdown,
  .has-dropdown.open>ul.dropdown{
    max-height:400px;
    transition:max-height 0.4s cubic-bezier(0.4,0,0.2,1);
  }

  /* Dropdown sub-links */
  .main-nav .dropdown a,
  .main-nav .dropdown-menu a,
  .main-nav .nav-dropdown-menu a{
    padding:12px 20px 12px 36px;
    font-size:0.86rem;color:var(--text-muted);
    border-left:2px solid var(--border);
    margin-left:20px;
  }
  .main-nav .dropdown a:hover,
  .main-nav .dropdown-menu a:hover,
  .main-nav .nav-dropdown-menu a:hover{
    color:var(--accent);
    border-left-color:var(--accent);
    background:none;
  }
  .main-nav .dropdown a.active,
  .main-nav .dropdown-menu a.active,
  .main-nav .nav-dropdown-menu a.active{
    color:var(--accent);border-left-color:var(--accent);
    font-weight:600;
  }

  /* Active dropdown parent */
  .has-dropdown.open>a,
  .has-dropdown.open>button,
  .nav-dropdown.open>a{
    color:var(--accent);background:none;
  }
}

/* ==========================================================
   HERO (index)
   ========================================================== */
.hero,.page-hero{
  padding:56px 20px 44px;
  text-align:center;
  background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);
  border-bottom:1px solid var(--border);
}
.hero h1,.page-hero h1{
  font-size:2.2rem;margin-bottom:0.6rem;letter-spacing:-0.03em;
}
.hero .subtitle,.hero .hero-subtitle,
.hero-inner .hero-subtitle,.page-hero p{
  font-size:1.05rem;color:var(--text-muted);
  max-width:620px;margin:0 auto;line-height:1.6;
}
.hero-inner{max-width:var(--max-w);margin:0 auto}
@media(max-width:600px){
  .hero,.page-hero{padding:40px 16px 32px}
  .hero h1,.page-hero h1{font-size:1.6rem}
}

/* ==========================================================
   MAIN CONTENT — global centering
   ========================================================== */
main{
  flex:1;padding:40px 0 60px;
  max-width:var(--max-w);
  margin:0 auto;
  width:100%;
  padding-left:20px;
  padding-right:20px;
}

/* --- Breadcrumb (often outside <main>, needs own centering) --- */
.breadcrumb{
  font-size:0.8rem;color:var(--text-muted);
  margin-bottom:0;
  max-width:var(--max-w);
  margin-left:auto;margin-right:auto;
  padding:16px 20px 0;
}
.breadcrumb ol{
  display:flex;flex-wrap:wrap;list-style:none;
  padding:0;margin:0;gap:0;
}
.breadcrumb li{display:flex;align-items:center}
.breadcrumb li+li::before{
  content:'/';margin:0 8px;color:var(--border-hover);font-size:0.75rem;
}
.breadcrumb a{color:var(--text-muted);font-size:0.8rem}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 6px;color:var(--border-hover)}
.breadcrumb>a+span,.breadcrumb>span{font-size:0.8rem}

/* --- Content with sidebar (article pages) --- */
.content-with-sidebar{
  display:grid;
  grid-template-columns:1fr 280px;
  gap:48px;align-items:start;
}
@media(max-width:960px){
  .content-with-sidebar{grid-template-columns:1fr;gap:32px}
}

/* --- Narrow content (legal pages, etc.) --- */
.content-narrow,.legal-content{max-width:760px;margin:0 auto}

/* --- Article body --- */
.article-body,.main-content{
  max-width:760px;line-height:1.8;min-width:0;
}
.article-body h1,.main-content h1{margin-top:0}
.article-body h2,.main-content h2{margin-top:2.5rem}
.article-body h3,.main-content h3{margin-top:2rem}
.article-body::after,.main-content::after{
  content:'';display:table;clear:both;
}

/* --- Intro Section (index) --- */
.intro-section{margin-bottom:20px}
.intro-section .container{max-width:none;padding:0}
.intro-text{max-width:760px;margin:0 auto}
.intro-text p{font-size:1rem;line-height:1.8}

/* --- Categories Section (index) --- */
.categories-section{margin-top:20px}
.categories-section .container{max-width:none;padding:0}
.categories-section h2{text-align:center;border-bottom:none;margin-bottom:1.5rem}

/* --- About Section --- */
.about-section,.about-content{max-width:760px;margin:0 auto}
.about-section h2,.about-content h2{margin-top:2rem}

/* --- Contact Section --- */
.contact-section{}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:40px;align-items:start;
}
@media(max-width:700px){.contact-grid{grid-template-columns:1fr}}

/* Contact info panel */
.contact-info-panel{
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);padding:32px;
}
.contact-info-panel h2{
  font-size:1.15rem;margin-bottom:1.5rem;color:var(--accent);
  margin-top:0;padding-bottom:0.8rem;border-bottom:1px solid var(--border);
}
.contact-info-panel p{font-size:0.9rem;margin-bottom:0;margin-top:1.2rem;color:var(--text-muted);line-height:1.65}

/* Contact details list */
ul.contact-details{
  list-style:none;padding:0;margin:0;
}
ul.contact-details li{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--border);
  font-size:0.92rem;color:var(--text-body);margin:0;
}
ul.contact-details li:last-child{border-bottom:none}
ul.contact-details li strong{
  flex-shrink:0;min-width:110px;
  color:var(--text-muted);font-weight:600;font-size:0.82rem;
  text-transform:uppercase;letter-spacing:0.5px;
  padding-top:1px;
}
ul.contact-details li a{
  color:var(--accent);word-break:break-all;
}
ul.contact-details li a:hover{color:var(--accent-hover)}

/* Contact form wrapper */
.contact-form-wrapper{
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);padding:32px;
}
.contact-form-wrapper h2{
  font-size:1.15rem;margin-bottom:1.5rem;color:var(--text-primary);
  margin-top:0;padding-bottom:0.8rem;border-bottom:1px solid var(--border);
}

/* --- Panels --- */
.panel{
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);padding:24px;margin-bottom:1.5rem;
}
.panel-header{
  font-size:0.75rem;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--text-muted);margin-bottom:12px;padding-bottom:10px;
  border-bottom:1px solid var(--border);font-weight:600;
}

/* ==========================================================
   SIDEBAR
   ========================================================== */
.sidebar,.sidebar-section{
  position:sticky;top:calc(var(--header-h) + 24px);
}

/* --- Sidebar blocks: .sidebar-panel, .sidebar-widget, .sidebar-section direct children --- */
.sidebar-panel,
.sidebar-widget,
.sidebar>.sidebar-section,
aside.sidebar>.sidebar-section{
  background:var(--bg-panel);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:0;
  margin-bottom:16px;
  overflow:hidden;
}

/* Sidebar headings: h3 or h4 */
.sidebar-panel h4,.sidebar-widget h4,
.sidebar-panel h3,.sidebar-widget h3,
.sidebar>.sidebar-section>h3,
aside.sidebar>.sidebar-section>h3{
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--accent);
  font-weight:700;
  margin:0;
  padding:14px 20px 12px;
  background:var(--bg-card);
  border-bottom:1px solid var(--border);
  position:relative;
}
/* Accent bar on sidebar heading */
.sidebar-panel h4::before,.sidebar-widget h4::before,
.sidebar-panel h3::before,.sidebar-widget h3::before,
.sidebar>.sidebar-section>h3::before,
aside.sidebar>.sidebar-section>h3::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;background:var(--accent);
}

/* Sidebar lists */
.sidebar-panel ul,.sidebar-widget ul,
.sidebar>.sidebar-section>ul,
aside.sidebar>.sidebar-section>ul{
  list-style:none;padding:8px 0;margin:0;
}
.sidebar-panel li,.sidebar-widget li,
.sidebar>.sidebar-section li,
aside.sidebar>.sidebar-section li{
  margin:0;
}
.sidebar-panel a,.sidebar-widget a,
.sidebar>.sidebar-section a,
aside.sidebar>.sidebar-section a{
  display:flex;align-items:center;gap:8px;
  font-size:0.84rem;color:var(--text-body);
  padding:9px 20px;
  transition:background var(--speed),color var(--speed),padding-left var(--speed);
  border-left:3px solid transparent;
}
.sidebar-panel a:hover,.sidebar-widget a:hover,
.sidebar>.sidebar-section a:hover,
aside.sidebar>.sidebar-section a:hover{
  background:var(--accent-glow);
  color:var(--accent);
  border-left-color:var(--accent);
  padding-left:24px;
}
/* Active link in sidebar (current page) */
.sidebar-panel a[aria-current="page"],
.sidebar-widget a[aria-current="page"],
.sidebar>.sidebar-section a[aria-current="page"],
aside.sidebar>.sidebar-section a[aria-current="page"],
.sidebar-panel a.active,.sidebar-widget a.active{
  background:var(--accent-glow);
  color:var(--accent);
  border-left-color:var(--accent);
  font-weight:600;
}

/* Sidebar paragraph (e.g. "Hızlı İpucu") */
.sidebar-panel p,.sidebar-widget p,
.sidebar>.sidebar-section>p,
aside.sidebar>.sidebar-section>p{
  font-size:0.84rem;color:var(--text-body);
  padding:14px 20px;margin:0;
  line-height:1.65;
}

@media(max-width:960px){
  .sidebar,.sidebar-section{position:static;order:2}
  /* On mobile, sidebar blocks become horizontal cards */
  .sidebar{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:16px;
  }
  .sidebar-panel,.sidebar-widget,
  .sidebar>.sidebar-section,
  aside.sidebar>.sidebar-section{
    margin-bottom:0;
  }
}

/* ==========================================================
   CARD GRID
   ========================================================== */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;margin:1.5rem 0;
}
.card{
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);padding:24px;
  transition:border-color var(--speed),transform var(--speed),box-shadow var(--speed);
}
.card:hover{
  border-color:var(--accent-dim);
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
.card h3{font-size:1rem;margin-bottom:0.6rem;margin-top:0;color:var(--accent)}
.card h3 a{color:var(--accent)}
.card h3 a:hover{color:var(--accent-hover)}
.card p{font-size:0.88rem;color:var(--text-muted);margin-bottom:0.8rem}
.card ul{list-style:none;padding:0;margin:0}
.card ul li{margin-bottom:4px}
.card ul a{font-size:0.84rem;color:var(--text-body)}
.card ul a:hover{color:var(--accent)}

/* ==========================================================
   FLOW MAP (index)
   ========================================================== */
.flow-map,.flow-map-section{
  margin:2rem 0;
}
.flow-map-section .container{padding:0}
.flow-map-section h2,.flow-map h2{
  text-align:center;border-bottom:none;margin-bottom:0.5rem;
}
.flow-map-section>p,.flow-map>p{
  text-align:center;max-width:540px;margin:0 auto 1.5rem;
}
.flow-map-buttons,.flow-targets{
  display:flex;gap:10px;justify-content:center;
  flex-wrap:wrap;margin:1.5rem 0;
}
.flow-map-btn,.flow-btn{
  padding:10px 22px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--r);
  color:var(--text-muted);cursor:pointer;font-size:0.88rem;
  font-family:var(--font);font-weight:500;
  transition:all var(--speed);
}
.flow-map-btn:hover,.flow-btn:hover,
.flow-map-btn.active,.flow-btn.active{
  border-color:var(--accent);color:var(--accent);
  background:var(--accent-glow);
  box-shadow:0 0 16px rgba(201,165,90,0.08);
}
.flow-map-routes{margin-top:1rem}
.flow-route{display:none;
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);padding:28px 28px 20px;
}
.flow-route.visible,.flow-route.active{display:block}
.flow-route h3{
  font-size:1.05rem;margin-bottom:1rem;
  color:var(--accent);margin-top:0;
}
.flow-route ol{counter-reset:step;list-style:none;padding:0;margin:0}
.flow-route li{
  counter-increment:step;
  padding:10px 16px 10px 52px;position:relative;
  border-left:2px solid var(--border);margin-left:16px;
  color:var(--text-body);
}
.flow-route li::before{
  content:counter(step);position:absolute;
  left:-15px;top:8px;width:28px;height:28px;
  background:var(--bg-panel);border:2px solid var(--accent-dim);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:0.75rem;color:var(--accent);font-weight:700;
}
.flow-route li:last-child{border-left-color:transparent}
.flow-route a{font-weight:600}

@media(max-width:600px){
  .flow-map-buttons,.flow-targets{gap:8px}
  .flow-map-btn,.flow-btn{padding:8px 16px;font-size:0.82rem}
  .flow-route{padding:20px 16px 14px}
  .flow-route li{padding-left:44px;margin-left:12px}
}

/* ==========================================================
   GLOSSARY
   ========================================================== */
.glossary-section{max-width:760px;margin:0 auto}
.glossary-list{margin:1.5rem 0}
.glossary-item{
  padding:18px 0;border-bottom:1px solid var(--border);
}
.glossary-item:last-child{border-bottom:none}
.glossary-term{
  font-weight:700;color:var(--accent);font-size:1rem;
  display:block;margin-bottom:4px;
}
.glossary-def{font-size:0.92rem;color:var(--text-body);margin-top:4px}

/* dt/dd variant */
.glossary-list dt{font-weight:700;color:var(--accent);font-size:1rem;margin-bottom:4px}
.glossary-list dd{font-size:0.92rem;color:var(--text-body);margin:0 0 18px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.glossary-list dd:last-child{border-bottom:none}

/* ==========================================================
   FAQ
   ========================================================== */
.faq-section{max-width:760px;margin:0 auto}
.faq-list{margin:1.5rem 0}
.faq-item{
  border:1px solid var(--border);border-radius:var(--r);
  margin-bottom:10px;overflow:hidden;
  transition:border-color var(--speed);
}
.faq-item.open{border-color:var(--border-hover)}
.faq-question{
  width:100%;background:var(--bg-panel);border:none;
  padding:18px 22px;text-align:left;
  color:var(--text-primary);font-size:0.95rem;font-weight:600;
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font);transition:background var(--speed);
}
.faq-question:hover{background:var(--bg-card)}
.faq-question:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}
.faq-icon{
  font-size:0.75rem;color:var(--text-muted);
  transition:transform var(--speed);flex-shrink:0;margin-left:16px;
}
.faq-item.open .faq-icon{transform:rotate(180deg)}
.faq-answer{display:none;padding:0 22px 20px;background:var(--bg-panel)}
.faq-item.open .faq-answer{display:block}
.faq-answer p{font-size:0.9rem;color:var(--text-body)}
.faq-answer p:last-child{margin-bottom:0}

/* ==========================================================
   CONTACT FORM
   ========================================================== */
.contact-form-wrapper{
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:var(--r);padding:28px;
}
.form-group{margin-bottom:1.3rem}
.form-group label{
  display:block;font-size:0.84rem;color:var(--text-body);
  margin-bottom:7px;font-weight:600;
}
.form-group label .required{color:var(--red)}
.form-group label .optional{color:var(--text-muted);font-weight:400;font-size:0.78rem}
.form-input,
input[type="text"],input[type="email"],input[type="tel"],
textarea{
  width:100%;padding:11px 16px;
  background:var(--bg-primary);border:1px solid var(--border);
  border-radius:var(--r);color:var(--text-primary);
  font-family:var(--font);font-size:0.92rem;
  transition:border-color var(--speed),box-shadow var(--speed);
}
.form-input:focus,
input[type="text"]:focus,input[type="email"]:focus,input[type="tel"]:focus,
textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}
textarea.form-input,textarea{resize:vertical;min-height:130px}

.form-consent,.checkbox-label{
  display:flex;gap:10px;align-items:flex-start;
  font-size:0.84rem;color:var(--text-muted);margin-bottom:1.3rem;
}
.form-consent input[type="checkbox"],
.checkbox-label input[type="checkbox"]{
  margin-top:3px;accent-color:var(--accent);flex-shrink:0;
  width:16px;height:16px;
}
.form-submit,
button[type="submit"]{
  display:inline-block;padding:13px 36px;
  background:var(--accent);color:var(--bg-primary);
  border:none;border-radius:var(--r);
  font-size:0.95rem;font-weight:700;cursor:pointer;
  font-family:var(--font);
  transition:background var(--speed),transform var(--speed);
}
.form-submit:hover,button[type="submit"]:hover{
  background:var(--accent-hover);transform:translateY(-1px);
}
.form-submit:disabled,button[type="submit"]:disabled{
  opacity:0.4;cursor:not-allowed;transform:none;
}
.form-message{
  margin-top:1rem;padding:14px 18px;
  border-radius:var(--r);font-size:0.9rem;display:none;
}
.form-message.success{
  display:block;background:rgba(94,168,94,0.12);
  color:var(--green);border:1px solid rgba(94,168,94,0.25);
}
.form-message.error{
  display:block;background:rgba(196,92,84,0.12);
  color:var(--red);border:1px solid rgba(196,92,84,0.25);
}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}

/* ==========================================================
   ARTICLE IMAGES
   ========================================================== */
.article-img{margin:1.5rem 0;overflow:hidden}
.article-img img{
  display:block;max-width:100%;height:auto;
  border-radius:var(--r);border:1px solid var(--border);
}
.article-img figcaption{
  font-size:0.78rem;color:var(--text-muted);
  margin-top:8px;font-style:italic;line-height:1.4;
}
.img-float-right{float:right;margin:0.3rem 0 1.2rem 1.5rem;max-width:320px}
.img-float-left{float:left;margin:0.3rem 1.5rem 1.2rem 0;max-width:320px}
.img-float-right img,.img-float-left img{width:100%;height:auto}
@media(max-width:640px){
  .img-float-right,.img-float-left{
    float:none;max-width:100%;margin:1rem 0;
  }
}

/* ==========================================================
   TABLES
   ========================================================== */
.styled-table{
  width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:0.88rem;
  background:var(--bg-panel);border-radius:var(--r);overflow:hidden;
}
.styled-table th,.styled-table td{
  padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);
}
.styled-table th{
  font-size:0.75rem;text-transform:uppercase;letter-spacing:0.8px;
  color:var(--text-muted);font-weight:700;background:var(--bg-card);
}
.styled-table td{color:var(--text-body)}
.styled-table tr:last-child td{border-bottom:none}
.styled-table tr:hover td{background:rgba(255,255,255,0.02)}

/* Inline code */
code{
  font-family:var(--font-mono);background:var(--bg-card);
  padding:2px 7px;border-radius:4px;font-size:0.84em;
  color:var(--accent);border:1px solid var(--border);
}

/* ==========================================================
   BUTTONS (generic .btn variants used by some pages)
   ========================================================== */
.btn{
  display:inline-block;padding:10px 24px;
  border-radius:var(--r);font-size:0.88rem;font-weight:600;
  cursor:pointer;border:1px solid var(--border);
  transition:all var(--speed);font-family:var(--font);
  text-decoration:none;text-align:center;
}
.btn-primary,.btn-accept{
  background:var(--accent);color:var(--bg-primary);border-color:var(--accent);
}
.btn-primary:hover,.btn-accept:hover{background:var(--accent-hover);color:var(--bg-primary)}
.btn-secondary{
  background:transparent;color:var(--text-body);border-color:var(--border);
}
.btn-secondary:hover{border-color:var(--text-muted);color:var(--text-primary)}
.btn-outline{
  background:transparent;color:var(--text-muted);border-color:var(--border);
}
.btn-outline:hover{border-color:var(--text-muted);color:var(--text-body)}
.btn-cancel,.btn-settings{
  background:transparent;color:var(--text-muted);
  border-color:transparent;text-decoration:underline;
}
.btn-cancel:hover,.btn-settings:hover{color:var(--text-body)}

/* ==========================================================
   FOOTER
   ========================================================== */
.site-footer{
  background:var(--bg-secondary);border-top:1px solid var(--border);
  padding:48px 0 28px;margin-top:auto;
}
.footer-grid,.footer-inner{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:36px;margin-bottom:36px;
  max-width:var(--max-w);margin-left:auto;margin-right:auto;
  padding:0 20px;
}
/* .footer-container wrapper */
.footer-container{max-width:var(--max-w);margin:0 auto;padding:0 20px}
.footer-container .footer-grid,.footer-container .footer-inner{padding:0}

.footer-col,.footer-column{min-width:0}
.footer-col h4,.footer-column h4{
  font-size:0.72rem;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--text-muted);margin-bottom:14px;font-weight:700;
  padding-bottom:10px;border-bottom:1px solid var(--border);
}
.footer-col ul,.footer-column ul{list-style:none;padding:0;margin:0}
.footer-col li,.footer-column li{margin-bottom:5px}
.footer-col a,.footer-column a{
  font-size:0.84rem;color:var(--text-body);
  transition:color var(--speed);
}
.footer-col a:hover,.footer-column a:hover{color:var(--accent)}
.footer-bottom{
  text-align:center;padding-top:28px;
  border-top:1px solid var(--border);
  font-size:0.78rem;color:var(--text-muted);
  max-width:var(--max-w);margin:0 auto;padding-left:20px;padding-right:20px;
}

@media(max-width:600px){
  .footer-grid,.footer-inner{
    grid-template-columns:1fr 1fr;gap:24px;
  }
}
@media(max-width:400px){
  .footer-grid,.footer-inner{grid-template-columns:1fr}
}

/* ==========================================================
   COOKIE BANNER
   ========================================================== */
.cookie-banner{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:var(--bg-secondary);border-top:1px solid var(--border);
  padding:22px 24px;z-index:9000;
  box-shadow:0 -8px 32px rgba(0,0,0,0.5);
}
.cookie-banner.visible{display:block}
.cookie-inner,.cookie-banner-inner,.cookie-banner-content,.cookie-content{
  max-width:var(--max-w);margin:0 auto;
}
.cookie-text,.cookie-banner p,.cookie-content p,.cookie-banner-content p{
  font-size:0.86rem;color:var(--text-body);margin-bottom:14px;
}
.cookie-text a,.cookie-banner a,.cookie-content a{color:var(--accent)}

.cookie-actions,.cookie-banner-actions{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
}
.cookie-btn{
  padding:9px 22px;border-radius:var(--r);
  font-size:0.84rem;font-weight:600;cursor:pointer;
  border:1px solid var(--border);
  transition:all var(--speed);font-family:var(--font);
}
.cookie-btn-accept,.cookie-accept{
  background:var(--accent);color:var(--bg-primary);border-color:var(--accent);
}
.cookie-btn-accept:hover,.cookie-accept:hover{background:var(--accent-hover)}
.cookie-btn-reject,.cookie-reject{
  background:transparent;color:var(--text-body);border-color:var(--border);
}
.cookie-btn-reject:hover,.cookie-reject:hover{
  border-color:var(--text-muted);color:var(--text-primary);
}
.cookie-btn-settings,.cookie-settings,.cookie-settings-open{
  background:transparent;color:var(--text-muted);
  border-color:transparent;text-decoration:underline;
  padding:9px 14px;
}
.cookie-btn-settings:hover,.cookie-settings:hover,.cookie-settings-open:hover{
  color:var(--text-body);
}

/* --- Cookie Modal --- */
.cookie-modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,0.65);z-index:9500;
  align-items:center;justify-content:center;
}
.cookie-modal-overlay.visible{display:flex}

.cookie-modal,.cookie-modal-content,.cookie-modal-inner{
  background:var(--bg-panel);border:1px solid var(--border);
  border-radius:calc(var(--r) + 4px);padding:32px;
  max-width:520px;width:92%;max-height:80vh;overflow-y:auto;
}
.cookie-modal h2,.cookie-modal h3,
.cookie-modal-content h2,.cookie-modal-content h3{
  margin-bottom:0.8rem;font-size:1.15rem;margin-top:0;
}
.cookie-modal p,.cookie-modal-content p{
  font-size:0.88rem;color:var(--text-body);margin-bottom:1rem;
}

/* Cookie option rows */
.cookie-option,.cookie-category{
  padding:16px 0;border-bottom:1px solid var(--border);
}
.cookie-option:last-of-type,.cookie-category:last-of-type{border-bottom:none}
.cookie-option-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:4px;
}
.cookie-option-header label{
  font-weight:600;font-size:0.92rem;color:var(--text-primary);
  cursor:pointer;
}
.cookie-option-header input[type="checkbox"]{
  width:18px;height:18px;accent-color:var(--accent);cursor:pointer;
}
.cookie-option-header input[type="checkbox"]:disabled{
  opacity:0.5;cursor:not-allowed;
}
.cookie-option p,.cookie-category p{
  font-size:0.8rem;color:var(--text-muted);margin:4px 0 0;
}

/* Toggle switch variant */
.cookie-toggle{position:relative;width:44px;height:24px;flex-shrink:0;margin-left:16px}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle-slider{
  position:absolute;inset:0;background:var(--border-hover);
  border-radius:12px;cursor:pointer;transition:background var(--speed);
}
.cookie-toggle-slider::after{
  content:'';position:absolute;width:18px;height:18px;
  border-radius:50%;background:#fff;top:3px;left:3px;
  transition:transform var(--speed);
}
.cookie-toggle input:checked+.cookie-toggle-slider{background:var(--accent)}
.cookie-toggle input:checked+.cookie-toggle-slider::after{transform:translateX(20px)}
.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:0.5;cursor:not-allowed}

.cookie-modal-actions{
  display:flex;gap:10px;margin-top:20px;justify-content:flex-end;
}
.cookie-btn-save,.cookie-save{
  background:var(--accent);color:var(--bg-primary);border:none;
  padding:10px 24px;border-radius:var(--r);font-weight:700;
  cursor:pointer;font-family:var(--font);font-size:0.88rem;
  transition:background var(--speed);
}
.cookie-btn-save:hover,.cookie-save:hover{background:var(--accent-hover)}
.cookie-modal-close,.cookie-close{
  background:transparent;color:var(--text-muted);border:1px solid var(--border);
  padding:10px 24px;border-radius:var(--r);cursor:pointer;
  font-family:var(--font);font-size:0.88rem;
  transition:all var(--speed);
}
.cookie-modal-close:hover,.cookie-close:hover{
  border-color:var(--text-muted);color:var(--text-body);
}
.cookie-reopen-settings{
  background:var(--bg-card);border:1px solid var(--border);
  color:var(--accent);padding:10px 20px;border-radius:var(--r);
  cursor:pointer;font-family:var(--font);font-size:0.88rem;
  font-weight:600;transition:all var(--speed);
}
.cookie-reopen-settings:hover{
  border-color:var(--accent);background:var(--accent-glow);
}

/* ==========================================================
   SITEMAP PAGE
   ========================================================== */
.sitemap-section{}
.sitemap-columns{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:28px;
}
.sitemap-columns h3,.sitemap-col h3{
  font-size:0.92rem;margin-bottom:0.8rem;color:var(--accent);
  padding-bottom:8px;border-bottom:1px solid var(--border);margin-top:0;
}
.sitemap-columns ul,.sitemap-col ul{list-style:none;padding:0;margin:0}
.sitemap-columns li,.sitemap-col li{margin-bottom:6px}
.sitemap-columns a,.sitemap-col a{font-size:0.88rem;color:var(--text-body)}
.sitemap-columns a:hover,.sitemap-col a:hover{color:var(--accent)}

/* ==========================================================
   404 PAGE
   ========================================================== */
.page-404{text-align:center;padding:80px 20px}
.page-404 h1{
  font-size:5rem;color:var(--accent);margin-bottom:0.5rem;
  font-weight:800;letter-spacing:-0.04em;
}
.page-404 p{font-size:1.05rem;max-width:440px;margin:0 auto}
.page-404 .error-message{font-size:1.3rem;font-weight:600;color:var(--text-primary);margin-bottom:0.5rem}
.page-404 .error-description{color:var(--text-muted)}
.page-404 .btn-home,.page-404 .btn-primary,.page-404 .btn{
  display:inline-block;margin-top:2rem;padding:13px 32px;
  background:var(--accent);color:var(--bg-primary);
  border-radius:var(--r);font-weight:700;border:none;
}
.page-404 .btn-home:hover,.page-404 .btn-primary:hover{
  background:var(--accent-hover);color:var(--bg-primary);
}

/* ==========================================================
   SVG Placeholder (kept for backward compat)
   ========================================================== */
.diagram-placeholder,.svg-placeholder,.image-placeholder{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r);padding:24px;margin:1.5rem 0;text-align:center;
}
.diagram-placeholder svg,.svg-placeholder svg{max-width:100%;height:auto}

/* ==========================================================
   UTILITY
   ========================================================== */
.text-center{text-align:center}
.mt-2{margin-top:2rem}
.mb-2{margin-bottom:2rem}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);border:0;
}

/* ==========================================================
   PRINT
   ========================================================== */
@media print{
  .site-header,.site-footer,.cookie-banner,.cookie-modal-overlay,
  .sidebar,.sidebar-section,.nav-toggle{display:none!important}
  body{background:#fff;color:#222}
  *{color:#222!important;border-color:#ccc!important;background:transparent!important}
  a{text-decoration:underline}
  .container,.content-with-sidebar,.content-narrow{max-width:100%;padding:0}
  .content-with-sidebar{display:block}
  .article-img img{border:1px solid #ccc}
}
