/*
Theme Name: Asma for Ward 2
Theme URI: https://asmaalwahsh.ca
Author: Asma Alwahsh Campaign
Description: A clean, professional, and accessible campaign theme for Asma Alwahsh.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: asma-ward2
Tags: one-column, custom-menu, accessibility-ready, block-styles
*/

:root {
  --color-primary: #1B3A5C;
  --color-primary-light: #2E6BA6;
  --color-primary-dark: #122840;
  --color-accent: #E8553D;
  --color-accent-hover: #D04530;
  --color-white: #FFFFFF;
  --color-surface: #F5F7FA;
  --color-surface-alt: #EDF1F7;
  --color-text: #1A1A2E;
  --color-text-secondary: #4A5568;
  --color-border: #E2E8F0;
  --color-success: #2D8B4E;
  --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --fs-base: 1.125rem;
  --fs-sm: 0.9375rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.5rem;
  --fs-2xl: 2rem;
  --fs-3xl: 2.5rem;
  --fs-4xl: 3.25rem;
  --fw-normal: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --lh-body: 1.7;
  --lh-heading: 1.2;
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2rem;
  --space-xl: 3rem;
  --space-2xl: 4rem;
  --space-3xl: 5rem;
  --section-py: 5rem;
  --max-width: 1200px;
  --radius: 8px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);
  --transition: 0.3s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--font-family);font-size:var(--fs-base);font-weight:var(--fw-normal);line-height:var(--lh-body);color:var(--color-text);background:var(--color-white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
img,picture,video,svg{display:block;max-width:100%;height:auto;}
a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition);}
a:hover,a:focus{color:var(--color-accent);}
a:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;border-radius:2px;}
ul,ol{list-style:none;}
h1,h2,h3,h4,h5,h6{font-weight:var(--fw-bold);line-height:var(--lh-heading);color:var(--color-primary);}
h1{font-size:var(--fs-4xl);}
h2{font-size:var(--fs-3xl);}
h3{font-size:var(--fs-xl);}
p{margin-bottom:var(--space-sm);}
p:last-child{margin-bottom:0;}

.skip-link{position:absolute;top:-100%;left:var(--space-sm);background:var(--color-accent);color:#fff;padding:var(--space-xs) var(--space-sm);z-index:10000;border-radius:0 0 var(--radius) var(--radius);font-weight:var(--fw-semibold);transition:top var(--transition);}
.skip-link:focus{top:0;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}

.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-md);}
.section{padding:var(--section-py) 0;}
.section--surface{background:var(--color-surface);}
.section--primary{background:var(--color-primary);color:var(--color-white);}
.section--primary h2,.section--primary h3{color:var(--color-white);}
.section-header{text-align:center;margin-bottom:var(--space-2xl);max-width:700px;margin-left:auto;margin-right:auto;}
.section-header p{color:var(--color-text-secondary);font-size:var(--fs-lg);margin-top:var(--space-sm);}
.grid{display:grid;gap:var(--space-lg);}
.grid--2{grid-template-columns:1fr;}
.grid--3{grid-template-columns:1fr;}
.grid--4{grid-template-columns:1fr;}

@media(min-width:768px){
  .grid--2{grid-template-columns:repeat(2,1fr);}
  .grid--3{grid-template-columns:repeat(2,1fr);}
  .grid--4{grid-template-columns:repeat(2,1fr);}
}
@media(min-width:1024px){
  .grid--3{grid-template-columns:repeat(3,1fr);}
  .grid--4{grid-template-columns:repeat(4,1fr);}
}

.site-header{background:var(--color-white);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1000;transition:box-shadow var(--transition);}
.site-header.scrolled{box-shadow:var(--shadow-md);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);max-width:var(--max-width);margin:0 auto;}
.site-brand{display:flex;flex-direction:column;}
.site-brand__name{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--color-primary);line-height:1.1;text-decoration:none;}
.site-brand__name:hover{color:var(--color-primary);}
.site-brand__tagline{font-size:var(--fs-sm);color:var(--color-text-secondary);font-weight:var(--fw-medium);}

.menu-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-xs);z-index:1001;}
.menu-toggle span{display:block;width:26px;height:3px;background:var(--color-primary);border-radius:2px;transition:var(--transition);}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(5px,6px);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px);}

.main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--color-white);border-bottom:2px solid var(--color-border);padding:var(--space-sm) 0;box-shadow:var(--shadow-md);}
.main-nav.is-open{display:block;}
.main-nav ul{display:flex;flex-direction:column;}
.main-nav li{border-bottom:1px solid var(--color-border);}
.main-nav li:last-child{border-bottom:none;}
.main-nav a{display:block;padding:var(--space-sm) var(--space-md);font-weight:var(--fw-medium);color:var(--color-text);transition:background var(--transition),color var(--transition);}
.main-nav a:hover,.main-nav a:focus,.main-nav .current-menu-item a{color:var(--color-accent);background:var(--color-surface);}

@media(min-width:768px){
  .menu-toggle{display:none;}
  .main-nav{display:flex!important;position:static;border:none;box-shadow:none;padding:0;}
  .main-nav ul{flex-direction:row;gap:var(--space-xs);}
  .main-nav li{border:none;}
  .main-nav a{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius);font-size:var(--fs-sm);}
  .main-nav a:hover,.main-nav a:focus,.main-nav .current-menu-item a{background:var(--color-surface);}
}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:0.875rem 2rem;font-family:var(--font-family);font-size:var(--fs-base);font-weight:var(--fw-semibold);border-radius:var(--radius);border:2px solid transparent;cursor:pointer;transition:all var(--transition);text-decoration:none;line-height:1.2;}
.btn:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;}
.btn--primary{background:var(--color-accent);color:var(--color-white);border-color:var(--color-accent);}
.btn--primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:var(--color-white);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn--secondary{background:transparent;color:var(--color-white);border-color:var(--color-white);}
.btn--secondary:hover{background:var(--color-white);color:var(--color-primary);}
.btn--outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary);}
.btn--outline:hover{background:var(--color-primary);color:var(--color-white);transform:translateY(-2px);}
.btn--sm{padding:0.625rem 1.25rem;font-size:var(--fs-sm);}
.btn--lg{padding:1rem 2.5rem;font-size:var(--fs-lg);}
.btn--block{width:100%;text-align:center;}

.hero{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);padding:var(--space-3xl) 0;position:relative;overflow:hidden;}
.hero::after{content:'';position:absolute;top:0;right:0;bottom:0;width:50%;background:linear-gradient(135deg,rgba(46,107,166,0.15) 0%,rgba(27,58,92,0) 100%);pointer-events:none;}
.hero .container{position:relative;z-index:1;}
.hero-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);align-items:center;}
.hero-content h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:var(--space-md);color:var(--color-white);}
.hero-content p{font-size:var(--fs-lg);opacity:0.9;margin-bottom:var(--space-lg);max-width:540px;}
.hero-photo{display:flex;justify-content:center;}
.hero-photo__placeholder{width:100%;max-width:400px;aspect-ratio:3/4;background:linear-gradient(135deg,rgba(255,255,255,0.1),rgba(255,255,255,0.05));border:2px dashed rgba(255,255,255,0.3);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-lg);color:rgba(255,255,255,0.5);font-size:var(--fs-sm);}

@media(min-width:768px){
  .hero{padding:var(--space-3xl) 0 6rem;}
  .hero-grid{grid-template-columns:1fr 1fr;}
}

.hero-signup{background:rgba(255,255,255,0.1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius-lg);padding:var(--space-lg);margin-top:var(--space-md);}
.hero-signup h3{color:var(--color-white);font-size:var(--fs-lg);margin-bottom:var(--space-sm);}
.signup-form{display:flex;flex-direction:column;gap:var(--space-sm);}
.signup-form input[type="text"],
.signup-form input[type="email"]{padding:0.875rem 1rem;border:1px solid rgba(255,255,255,0.3);border-radius:var(--radius);background:rgba(255,255,255,0.15);color:var(--color-white);font-family:var(--font-family);font-size:var(--fs-base);transition:border-color var(--transition);}
.signup-form input::placeholder{color:rgba(255,255,255,0.6);}
.signup-form input:focus{outline:none;border-color:var(--color-accent);background:rgba(255,255,255,0.2);}

@media(min-width:768px){
  .signup-form{flex-direction:row;flex-wrap:wrap;}
  .signup-form input{flex:1;min-width:140px;}
  .signup-form .btn{flex-shrink:0;}
}

.card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:transform var(--transition),box-shadow var(--transition);}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.card__icon{width:56px;height:56px;background:var(--color-surface);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md);font-size:1.75rem;color:var(--color-primary-light);}
.card__title{font-size:var(--fs-xl);margin-bottom:var(--space-sm);color:var(--color-primary);}
.card__text{color:var(--color-text-secondary);line-height:var(--lh-body);}

.card--priority{border-top:4px solid var(--color-primary-light);position:relative;}
.card--priority:nth-child(2){border-top-color:var(--color-accent);}
.card--priority:nth-child(3){border-top-color:var(--color-success);}
.card--priority:nth-child(4){border-top-color:#8B5CF6;}

.ward-map{background:var(--color-surface);}
.ward-map-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);align-items:center;}
.ward-map__placeholder{width:100%;aspect-ratio:4/3;background:var(--color-white);border:2px dashed var(--color-border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-lg);color:var(--color-text-secondary);}
.ward-map__embed{width:100%;aspect-ratio:4/3;background:var(--color-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);}
.ward-map__embed{width:100%;aspect-ratio:4/3;background:var(--color-white);border:2px dashed var(--color-border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-lg);color:var(--color-text-secondary);}
.ward-map__content h2{margin-bottom:var(--space-md);}
.ward-map__content p{color:var(--color-text-secondary);margin-bottom:var(--space-sm);}

@media(min-width:768px){
  .ward-map-grid{grid-template-columns:1fr 1fr;}
}

.quote-section{background:var(--color-primary);color:var(--color-white);text-align:center;}
.quote-section blockquote{font-size:clamp(var(--fs-lg),3vw,var(--fs-2xl));font-weight:var(--fw-medium);font-style:italic;line-height:1.5;max-width:800px;margin:0 auto;position:relative;padding:0 var(--space-lg);}
.quote-section blockquote::before{content:'\\201C';font-size:5rem;position:absolute;top:-1.5rem;left:-0.5rem;color:rgba(255,255,255,0.2);font-family:Georgia,serif;line-height:1;}
.quote-section cite{display:block;margin-top:var(--space-md);font-style:normal;font-weight:var(--fw-semibold);font-size:var(--fs-base);opacity:0.85;}

.bio-hero{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-white);padding:var(--space-3xl) 0 var(--space-2xl);text-align:center;}
.bio-hero h1{color:var(--color-white);margin-bottom:var(--space-sm);}
.bio-hero p{font-size:var(--fs-lg);opacity:0.85;max-width:600px;margin:0 auto;}
.bio-photo{width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,0.1);border:3px solid rgba(255,255,255,0.3);margin:0 auto var(--space-lg);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.5);font-size:var(--fs-sm);text-align:center;overflow:hidden;}
.bio-narrative{max-width:800px;margin:0 auto;}
.bio-narrative h2{margin-bottom:var(--space-md);text-align:center;}
.bio-narrative p{margin-bottom:var(--space-md);color:var(--color-text-secondary);font-size:var(--fs-base);}
.bio-narrative p:first-of-type{font-size:var(--fs-lg);color:var(--color-text);}

.timeline{position:relative;max-width:700px;margin:0 auto;padding-left:var(--space-2xl);}
.timeline::before{content:'';position:absolute;left:12px;top:0;bottom:0;width:3px;background:var(--color-border);border-radius:2px;}
.timeline-item{position:relative;padding-bottom:var(--space-lg);padding-left:var(--space-md);}
.timeline-item::before{content:'';position:absolute;left:calc(-1 * var(--space-2xl) + 6px);top:6px;width:14px;height:14px;background:var(--color-primary-light);border-radius:50%;border:3px solid var(--color-white);box-shadow:0 0 0 2px var(--color-primary-light);z-index:1;}
.timeline-item:last-child{padding-bottom:0;}
.timeline-item__year{font-weight:var(--fw-bold);color:var(--color-primary);font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:var(--space-xs);}
.timeline-item__text{color:var(--color-text-secondary);}

.awards-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md);max-width:700px;margin:0 auto;}
.award-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-lg);border-left:4px solid var(--color-accent);}
.award-card__icon{font-size:2rem;flex-shrink:0;line-height:1;}
.award-card__title{font-weight:var(--fw-semibold);color:var(--color-primary);margin-bottom:var(--space-xs);}
.award-card__desc{color:var(--color-text-secondary);font-size:var(--fs-sm);}

@media(min-width:768px){
  .awards-grid{grid-template-columns:repeat(2,1fr);}
}

.involve-hero{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-white);padding:var(--space-3xl) 0 var(--space-2xl);text-align:center;}
.involve-hero h1{color:var(--color-white);margin-bottom:var(--space-sm);}
.involve-hero p{font-size:var(--fs-lg);opacity:0.85;max-width:600px;margin:0 auto;}

.form-section{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);margin-bottom:var(--space-lg);}
.form-section h2{margin-bottom:var(--space-sm);font-size:var(--fs-2xl);}
.form-section>p{color:var(--color-text-secondary);margin-bottom:var(--space-lg);}

.form-placeholder{background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius);padding:var(--space-2xl);text-align:center;color:var(--color-text-secondary);}
.form-placeholder p{font-size:var(--fs-sm);}

.form-section input[type="text"],
.form-section input[type="email"],
.form-section textarea{width:100%;padding:0.875rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);font-family:var(--font-family);font-size:var(--fs-base);color:var(--color-text);transition:border-color var(--transition);margin-bottom:var(--space-sm);}
.form-section input:focus,
.form-section textarea:focus{outline:none;border-color:var(--color-primary-light);box-shadow:0 0 0 3px rgba(46,107,166,0.15);}
.form-section label{display:block;font-weight:var(--fw-medium);margin-bottom:var(--space-xs);color:var(--color-text);}

.donation-placeholder{background:linear-gradient(135deg,var(--color-surface),var(--color-surface-alt));border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;}
.donation-placeholder__icon{font-size:3rem;margin-bottom:var(--space-md);opacity:0.5;}
.donation-placeholder h2{margin-bottom:var(--space-sm);}
.donation-placeholder p{color:var(--color-text-secondary);max-width:500px;margin:0 auto;}

.site-footer{background:var(--color-primary-dark);color:rgba(255,255,255,0.85);padding:var(--space-2xl) 0 0;}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg);}
.footer-col h4{color:var(--color-white);font-size:var(--fs-base);margin-bottom:var(--space-sm);font-weight:var(--fw-semibold);}
.footer-col a{color:rgba(255,255,255,0.7);transition:color var(--transition);}
.footer-col a:hover{color:var(--color-white);}
.footer-col ul li{margin-bottom:var(--space-xs);}
.footer-col p{font-size:var(--fs-sm);line-height:1.6;color:rgba(255,255,255,0.7);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);margin-top:var(--space-2xl);padding:var(--space-md) 0;text-align:center;}
.footer-disclaimer{font-size:var(--fs-sm);color:rgba(255,255,255,0.5);margin-bottom:var(--space-xs);}
.footer-copyright{font-size:var(--fs-sm);color:rgba(255,255,255,0.4);}

@media(min-width:768px){
  .footer-grid{grid-template-columns:2fr 1fr 1fr;}
}

.page-header{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-white);padding:var(--space-3xl) 0 var(--space-2xl);text-align:center;}
.page-header h1{color:var(--color-white);margin-bottom:var(--space-sm);}

.fade-in{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease;}
.fade-in.is-visible{opacity:1;transform:translateY(0);}

@media(prefers-reduced-motion:reduce){
  .fade-in{opacity:1;transform:none;transition:none;}
  *{transition-duration:0.01ms!important;animation-duration:0.01ms!important;}
}

.alignwide{max-width:calc(var(--max-width) + 200px);margin-left:auto;margin-right:auto;}
.alignfull{width:100%;max-width:100%;}
.aligncenter{text-align:center;}
.wp-block-image img{border-radius:var(--radius);}

@media print{
  .site-header,.site-footer,.menu-toggle,.btn{display:none!important;}
  body{font-size:12pt;color:#000;background:#fff;}
  .hero{background:#f5f5f5!important;color:#000!important;}
  .hero h1,.hero p{color:#000!important;}
}

/* Desktop Navigation Fix */
@media (min-width: 768px) {
    .menu-toggle {
        display: none !important;
    }
    .main-nav {
        display: flex !important;
        position: static !important;
        box-shadow: none !important;
        border: none !important;
        padding: 0 !important;
    }
    .main-nav ul {
        display: flex !important;
        flex-direction: row !important;
        gap: 1.5rem !important;
    }
    .main-nav li {
        border: none !important;
    }
    .main-nav a {
        padding: 0.5rem 1rem !important;
    }
}
