/*
Theme Name: Sunrise School
Theme URI: https://example.com/
Author: Rizwan Ali
Description: A one-page school website theme with notebook-ruled design, notice board, principal's message, academics, admissions and contact sections. School details, principal photo/message and contact info are editable via Appearance > Customize. Notices are managed from the "Notices" menu in wp-admin.
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sunrise-school
*/

:root{
  --board:#14453D;
  --chalk:#FBF9F2;
  --marigold:#F2A93B;
  --rule:#B9CDE4;
  --margin-red:#D9634E;
  --ink:#22302C;
  --line:34px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:'Public Sans',system-ui,sans-serif;
  color:var(--ink);
  background:var(--chalk);
  line-height:1.6;
}
h1,h2,h3{font-family:'Fraunces',serif;line-height:1.15}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* Notebook ruled background */
.ruled{
  background-image:
    linear-gradient(to right, transparent 63px, var(--margin-red) 63px, var(--margin-red) 65px, transparent 65px),
    repeating-linear-gradient(to bottom, transparent 0, transparent calc(var(--line) - 1px), var(--rule) calc(var(--line) - 1px), var(--rule) var(--line));
  background-color:var(--chalk);
}
@media (max-width:640px){
  .ruled{background-image:repeating-linear-gradient(to bottom, transparent 0, transparent calc(var(--line) - 1px), var(--rule) calc(var(--line) - 1px), var(--rule) var(--line));}
}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--board);color:var(--chalk);
  border-bottom:3px solid var(--marigold);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;max-width:1080px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.crest{
  width:42px;height:42px;border-radius:50%;
  background:var(--marigold);color:var(--board);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;font-weight:700;font-size:1.1rem;
  overflow:hidden;
}
.crest img{width:100%;height:100%;object-fit:cover}
.brand b{font-family:'Fraunces',serif;font-weight:700;font-size:1.05rem;letter-spacing:.3px}
.brand small{display:block;font-size:.7rem;opacity:.8;font-weight:400}
.nav nav ul{display:flex;gap:26px;list-style:none}
.nav nav a{text-decoration:none;font-size:.9rem;font-weight:500;opacity:.9;padding:6px 2px;border-bottom:2px solid transparent}
.nav nav a:hover,.nav nav a:focus-visible{opacity:1;border-bottom-color:var(--marigold);outline:none}
.menu-btn{display:none;background:none;border:1px solid rgba(251,249,242,.4);color:var(--chalk);padding:8px 12px;border-radius:6px;font-size:.9rem;cursor:pointer;font-family:inherit}
@media (max-width:820px){
  .menu-btn{display:block}
  .nav nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:var(--board);flex-direction:column;gap:0;padding:8px 24px 16px;border-bottom:3px solid var(--marigold)}
  .nav nav ul.open{display:flex}
  .nav nav a{display:block;padding:12px 0}
}

/* Hero */
.hero{padding:calc(var(--line)*2) 0 calc(var(--line)*3)}
.hero .wrap{padding-left:96px}
@media (max-width:640px){.hero .wrap{padding-left:24px}}
.eyebrow{
  display:inline-block;background:var(--marigold);color:var(--board);
  font-weight:700;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;
  padding:4px 12px;border-radius:3px;margin-bottom:var(--line);
}
.hero h1{
  font-size:clamp(2.2rem,5.5vw,4rem);font-weight:700;color:var(--board);
  max-width:16ch;margin-bottom:var(--line);
}
.hero p{max-width:52ch;font-size:1.05rem;margin-bottom:var(--line)}
.btn{
  display:inline-block;text-decoration:none;font-weight:600;font-size:.95rem;
  padding:13px 26px;border-radius:6px;border:2px solid var(--board);
  transition:transform .15s ease, box-shadow .15s ease;
  background:transparent;color:var(--board);cursor:pointer;font-family:inherit;
}
.btn:hover,.btn:focus-visible{transform:translateY(-2px);box-shadow:0 4px 0 rgba(20,69,61,.25);outline:none}
.btn.primary{background:var(--board);color:var(--chalk)}
.btn.ghost{margin-left:12px}
.quickstats{display:flex;flex-wrap:wrap;gap:32px;margin-top:calc(var(--line)*1.5)}
.quickstats div b{font-family:'Fraunces',serif;font-size:1.6rem;color:var(--board);display:block}
.quickstats div span{font-size:.85rem;opacity:.75}

/* Sections */
.section{padding:72px 0}
.sec-head{margin-bottom:40px}
.sec-head h2{font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--board)}
.sec-head p{max-width:60ch;margin-top:8px;opacity:.85}

/* Principal */
.principal{background:#fff;border-top:2px dashed var(--rule);border-bottom:2px dashed var(--rule)}
.principal-grid{display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:start}
@media (max-width:820px){.principal-grid{grid-template-columns:1fr;gap:28px}}
.principal-photo img,.photo-fallback{
  width:260px;height:300px;object-fit:cover;object-position:top;
  border:3px solid var(--board);border-radius:8px;
  box-shadow:8px 8px 0 var(--marigold);
  background:#fff;
}
.photo-fallback{
  display:grid;place-items:center;text-align:center;
  font-family:'Fraunces',serif;font-weight:700;font-size:1.2rem;color:var(--board);
  background:repeating-linear-gradient(to bottom, #fff 0, #fff 33px, var(--rule) 33px, var(--rule) 34px);
}
.principal-name{margin-top:22px;font-size:1rem;line-height:1.4}
.principal-name b{color:var(--board);font-size:1.05rem}
.principal-name span{font-size:.85rem;color:var(--margin-red);font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.principal-note blockquote{border-left:4px solid var(--marigold);padding-left:22px}
.principal-note blockquote p{margin-bottom:14px;max-width:62ch}
.principal-note .sign{font-family:'Fraunces',serif;font-weight:700;color:var(--board);font-size:1.05rem}

/* Notice board */
.notices{background:var(--board);color:var(--chalk)}
.notices .sec-head h2{color:var(--chalk)}
.notice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.note{
  background:var(--chalk);color:var(--ink);border-radius:4px;
  padding:22px 20px 18px;position:relative;
  box-shadow:0 6px 14px rgba(0,0,0,.25);
  transform:rotate(-.6deg);
}
.note:nth-child(2){transform:rotate(.7deg)}
.note:nth-child(3){transform:rotate(-.4deg)}
.note::before{
  content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  width:16px;height:16px;border-radius:50%;
  background:var(--margin-red);box-shadow:inset -2px -2px 3px rgba(0,0,0,.3);
}
.note time{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--margin-red)}
.note h3{font-size:1.05rem;margin:6px 0 8px;color:var(--board)}
.note p{font-size:.9rem}

/* Academics */
.stage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px}
.stage{
  border:2px solid var(--board);border-radius:8px;padding:26px 22px;
  background:#fff;position:relative;overflow:hidden;
}
.stage::after{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--marigold)}
.stage h3{color:var(--board);font-size:1.15rem;margin-bottom:4px}
.stage .cls{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--margin-red);margin-bottom:10px;display:block}
.stage p{font-size:.92rem}

/* Admissions */
.admissions{background:#F1EDE1}
.steps{counter-reset:step;display:grid;gap:0}
.step{
  counter-increment:step;display:grid;grid-template-columns:64px 1fr;gap:20px;
  padding:26px 0;border-bottom:2px dashed var(--rule);align-items:start;
}
.step:last-child{border-bottom:none}
.step::before{
  content:counter(step);
  font-family:'Fraunces',serif;font-weight:700;font-size:1.5rem;
  width:52px;height:52px;border-radius:50%;
  background:var(--board);color:var(--chalk);
  display:grid;place-items:center;
}
.step h3{color:var(--board);font-size:1.1rem;margin-bottom:4px}
.step p{font-size:.95rem;max-width:60ch}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-info p{margin-bottom:14px}
.contact-info b{color:var(--board)}
.contact-form-area .wpcf7 input,.contact-form-area .wpcf7 textarea,
.cform input,.cform textarea{
  width:100%;padding:12px 14px;font:inherit;font-size:.95rem;
  border:2px solid var(--board);border-radius:6px;background:#fff;color:var(--ink);
}
.cform label{display:block;font-weight:600;font-size:.85rem;margin:16px 0 6px;color:var(--board)}
.cform input:focus-visible,.cform textarea:focus-visible{outline:3px solid var(--marigold);outline-offset:1px}
.cform button{margin-top:20px}
.form-note{font-size:.85rem;margin-top:12px;color:var(--board);font-weight:600;display:none}

/* Footer */
.site-footer{background:var(--board);color:var(--chalk);padding:36px 0;border-top:3px solid var(--marigold)}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;font-size:.85rem}
.site-footer a{opacity:.85;text-decoration:none}
.site-footer a:hover{opacity:1;text-decoration:underline}

/* Blog/inner-page fallback */
.inner{padding:60px 0;min-height:50vh}
.inner article{margin-bottom:48px}
.inner h1,.inner h2{color:var(--board);margin-bottom:12px}
.inner .entry-content p{margin-bottom:14px;max-width:70ch}
