/* ================================================
   Grundschule Am Annaberg – Gemeinsames Stylesheet
   Farben: exakt aus SchuleNeu.rcd – Blau:#121290  Beige:#fbf5e0  Akzent:#d67551
   ================================================ */

:root{
  --blue:#121290;
  --blue-dark:#0d0d70;
  --blue-hover:#1a1ab0;
  --beige:#fbf5e0;
  --beige-soft:#fdf9ee;
  --cream:#fffef8;
  --accent:#d67551;
  --accent-dark:#b85f3d;
  --text:#282828;
  --text-muted:#5a5a7a;
  --border:#e8dfc8;
  --shadow:0 4px 20px rgba(18,18,144,.08);
  --shadow-lg:0 12px 40px rgba(18,18,144,.14);
  --radius:14px;
  --radius-lg:24px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Nunito',Tahoma,Geneva,sans-serif;font-size:17px;line-height:1.6;color:var(--text);background:var(--beige-soft);-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.2;letter-spacing:-.015em;color:var(--blue);}
h1{font-size:clamp(30px,4.5vw,52px);margin-bottom:20px}
h2{font-size:clamp(26px,3.5vw,40px);margin-bottom:18px}
h3{font-size:22px;margin-bottom:12px}
h4{font-size:18px;margin-bottom:10px}
p{margin-bottom:16px}
a{color:var(--blue);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-dark);text-decoration:underline}
img{max-width:100%;height:auto;display:block}
ul,ol{margin:0 0 18px 22px}
li{margin-bottom:8px}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

a:focus-visible, button:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px;}
.skip-link{position:absolute;top:-40px;left:8px;background:var(--blue);color:#fff;padding:10px 16px;border-radius:6px;z-index:1000;}
.skip-link:focus{top:8px}

.topbar{background:var(--blue-dark);color:#d8e2f0;font-size:14px;padding:10px 0;}
.topbar .container{display:flex;justify-content:flex-end;gap:22px;flex-wrap:wrap;}
.topbar a{color:#d8e2f0;display:inline-flex;align-items:center;gap:6px}
.topbar a:hover{color:#fff;text-decoration:none}
.topbar a::after{content:"↗";font-size:12px;opacity:.7}

.header{background:var(--cream);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow);}
.header .container{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px;gap:24px;}
.logo{display:flex;align-items:center;gap:14px;text-decoration:none;}
.logo:hover{text-decoration:none}
.logo img{width:56px;height:56px;object-fit:contain}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-text .school{font-family:'Fraunces',serif;font-size:22px;font-weight:600;color:var(--blue);}
.logo-text .sub{font-size:13px;color:var(--text-muted);letter-spacing:.02em;}

.nav{display:flex;gap:4px;align-items:center}
.nav > a, .nav-item > a{padding:10px 14px;border-radius:8px;color:var(--text);font-weight:600;font-size:15px;transition:background .15s,color .15s;display:inline-block;}
.nav > a:hover, .nav-item > a:hover{background:var(--beige);color:var(--blue);text-decoration:none;}
.nav > a.active, .nav-item > a.active{background:var(--blue);color:#fff;}
.nav-item{position:relative}
.nav-item.has-dropdown > a::after{content:" ▾";font-size:10px;opacity:.7;}
.dropdown{position:absolute;top:100%;left:0;background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:220px;padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:all .18s;}
.nav-item:hover .dropdown, .nav-item:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown a{display:block;padding:10px 14px;border-radius:8px;font-weight:500;color:var(--text);}
.dropdown a:hover{background:var(--beige);color:var(--blue);text-decoration:none;}
.menu-toggle{display:none;background:none;border:2px solid var(--blue);border-radius:8px;padding:8px 12px;font-size:18px;color:var(--blue);cursor:pointer;}

.page-header{background:linear-gradient(135deg,var(--beige) 0%,var(--beige-soft) 100%);padding:60px 0 50px;border-bottom:1px solid var(--border);}
.page-header .eyebrow{font-size:13px;font-weight:700;color:var(--accent-dark);text-transform:uppercase;letter-spacing:.16em;display:block;margin-bottom:12px;}
.page-header h1{margin-bottom:10px}
.page-header p.lead{font-size:19px;color:var(--text-muted);max-width:720px;}
.breadcrumb{font-size:14px;color:var(--text-muted);margin-bottom:20px;}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--blue)}

.hero{background:linear-gradient(135deg,var(--beige) 0%,var(--beige-soft) 100%);padding:80px 0 100px;position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;background:var(--blue);opacity:.04;border-radius:50%;}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;}
.hero-eyebrow{display:inline-block;font-size:14px;font-weight:700;color:var(--accent-dark);text-transform:uppercase;letter-spacing:.14em;margin-bottom:20px;}
.hero h1{font-size:clamp(36px,5vw,58px);margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--accent-dark);font-weight:500;}
.hero p.lead{font-size:19px;color:var(--text-muted);margin-bottom:34px;max-width:500px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

.hero-image{position:relative}
.hero-image .photo-frame{background:var(--cream);padding:14px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transform:rotate(1.5deg);transition:transform .3s;}
.hero-image .photo-frame:hover{transform:rotate(0)}
/* Kollegiumsfoto: contain damit das ganze Bild sichtbar ist */
.hero-image img{border-radius:12px;aspect-ratio:4/3;object-fit:contain;width:100%;background:var(--cream);}
.photo-caption{text-align:center;padding:12px 8px 4px;font-family:'Fraunces',serif;font-style:italic;color:var(--text-muted);font-size:15px;}

.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border-radius:10px;font-weight:700;font-size:16px;transition:all .2s;cursor:pointer;border:none;font-family:inherit;}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 14px rgba(214,117,81,.3);}
.btn-primary:hover{background:var(--accent-dark);text-decoration:none;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(214,117,81,.4);}
.btn-secondary{background:var(--cream);color:var(--blue);border:2px solid var(--blue);}
.btn-secondary:hover{background:var(--blue);color:#fff;text-decoration:none;}

.section{padding:80px 0}
.section-beige{background:var(--beige)}
.section-cream{background:var(--cream)}
.section-blue{background:var(--blue);color:#fff}
.section-blue h1, .section-blue h2, .section-blue h3{color:#fff}

.section-head{text-align:center;margin-bottom:50px;max-width:700px;margin-left:auto;margin-right:auto;}
.section-head .eyebrow{font-size:13px;font-weight:700;color:var(--accent-dark);text-transform:uppercase;letter-spacing:.16em;margin-bottom:14px;display:block;}
.section-head p{font-size:18px;color:var(--text-muted)}

.content{max-width:820px;margin:0 auto}
.content-wide{max-width:1100px;margin:0 auto}
.content p, .content li{font-size:17px;line-height:1.7;}
.content h2{margin-top:40px;margin-bottom:18px}
.content h3{margin-top:28px;margin-bottom:12px}
.content h2:first-child, .content h3:first-child{margin-top:0}
.content img{border-radius:var(--radius);margin:24px 0;box-shadow:var(--shadow);}
.content blockquote{border-left:4px solid var(--accent);padding:4px 0 4px 24px;margin:20px 0;font-style:italic;color:var(--text-muted);}

.quick{background:var(--cream);padding:70px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quick-card{background:var(--beige-soft);border:1px solid var(--border);padding:32px 28px;border-radius:var(--radius);transition:all .25s;text-decoration:none;color:var(--text);display:block;}
.quick-card:hover{background:var(--blue);color:#fff;text-decoration:none;transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blue);}
.quick-card:hover h3, .quick-card:hover p{color:#fff}
.quick-card:hover .quick-icon{background:#fff;color:var(--blue)}
.quick-icon{width:52px;height:52px;background:var(--blue);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px;transition:all .25s;}
.quick-card h3{font-size:22px;margin-bottom:8px}
.quick-card p{color:var(--text-muted);font-size:15px;margin-bottom:14px}
.quick-card .arrow{font-weight:700;color:var(--accent-dark)}
.quick-card:hover .arrow{color:#fff}

.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.news-card{background:var(--cream);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s, box-shadow .25s;display:flex;flex-direction:column;}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.news-image{aspect-ratio:16/10;background:var(--beige);display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--blue);}
.news-image img{width:100%;height:100%;object-fit:cover}
.news-body{padding:26px 28px 30px;flex:1;display:flex;flex-direction:column}
.news-date{font-size:13px;color:var(--accent-dark);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;}
.news-card h3{font-size:20px;margin-bottom:12px}
.news-card p{color:var(--text-muted);font-size:15px;margin-bottom:18px;flex:1}
.news-card a.read-more{font-weight:700;color:var(--blue);align-self:flex-start}
.news-card a.read-more:hover{color:var(--accent-dark);text-decoration:none}
.section-cta{text-align:center;margin-top:40px}

.article{background:var(--cream);border-radius:var(--radius);padding:36px 40px;margin-bottom:30px;box-shadow:var(--shadow);}
.article-meta{font-size:13px;color:var(--accent-dark);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;}
.article h2{margin-top:0;font-size:28px}
.article img{margin:20px 0;border-radius:12px}
.article-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:20px 0;}
.article-gallery img{margin:0;aspect-ratio:1;object-fit:cover}

.about{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.about-image{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;background:var(--beige);box-shadow:var(--shadow-lg);}
.about-image img{width:100%;height:100%;object-fit:cover}
.about-features{list-style:none;margin:24px 0 32px;padding:0}
.about-features li{padding:10px 0 10px 34px;position:relative;border-bottom:1px solid var(--border);margin-bottom:0;}
.about-features li:last-child{border-bottom:none}
.about-features li::before{content:"✓";position:absolute;left:0;top:11px;width:22px;height:22px;background:var(--blue);color:#fff;border-radius:50%;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;}

.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;}
.team-card{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .2s;}
.team-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.team-card h3{margin-bottom:6px;font-size:19px;color:var(--blue)}
.team-card p{margin-bottom:0;font-size:15px;color:var(--text-muted)}
.team-role{display:inline-block;background:var(--beige);color:var(--blue);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;margin-bottom:10px;letter-spacing:.04em;}

.contact{background:var(--blue);color:#fff;padding:90px 0}
.contact h2{color:#fff}
.contact .section-head p{color:#c5d2e5}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:20px}
.contact-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);padding:34px 28px;border-radius:var(--radius);text-align:center;}
.contact-card .icon{width:56px;height:56px;background:var(--accent);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 18px;}
.contact-card h3{color:#fff;font-size:20px;margin-bottom:12px}
.contact-card p, .contact-card a{color:#d8e2f0;font-size:15px;line-height:1.7;margin:0}
.contact-card a:hover{color:#fff;text-decoration:underline}

.infobox{background:var(--beige);border-left:4px solid var(--accent);padding:20px 24px;border-radius:8px;margin:24px 0;}
.infobox h3{color:var(--accent-dark);font-size:18px;margin-bottom:8px}
.infobox p:last-child{margin-bottom:0}
.warning-box{background:#fff5e6;border-left:4px solid var(--accent);padding:20px 24px;border-radius:8px;margin:24px 0;}

.styled-table{width:100%;border-collapse:collapse;background:var(--cream);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin:20px 0;}
.styled-table th, .styled-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border);}
.styled-table th{background:var(--blue);color:#fff;font-weight:700;font-size:15px;}
.styled-table tr:last-child td{border-bottom:none}
.styled-table tr:nth-child(even){background:var(--beige-soft)}

.footer{background:var(--blue-dark);color:#a8b5cc;padding:60px 0 30px;font-size:15px;margin-top:0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.footer h4{color:#fff;font-size:16px;margin-bottom:18px;font-family:'Nunito',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.08em;}
.footer ul{list-style:none;margin:0;padding:0}
.footer li{margin-bottom:10px}
.footer a{color:#a8b5cc}
.footer a:hover{color:#fff}
.footer p{color:#a8b5cc;margin-bottom:6px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;}

@media (max-width:900px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;padding:16px;gap:4px;box-shadow:var(--shadow-lg);border-top:1px solid var(--border);}
  .nav.open{display:flex}
  .nav > a, .nav-item > a{width:100%;padding:12px 16px}
  .nav-item{width:100%}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:4px 0 4px 20px;min-width:0;background:transparent;}
  .menu-toggle{display:block}
  .hero{padding:50px 0 70px}
  .hero .container{grid-template-columns:1fr;gap:40px}
  .hero-image{order:-1}
  .quick-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .about{grid-template-columns:1fr;gap:40px}
  .about-image{order:-1}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .section{padding:60px 0}
  .topbar .container{justify-content:center;gap:16px}
  .article{padding:28px 24px}
}

@media (max-width:500px){
  .footer-grid{grid-template-columns:1fr}
  .logo-text .school{font-size:18px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .btn{justify-content:center}
}
