/*
Theme Name: Emerald City
Theme URI: https://example.com/emerald-city
Author: Oz Atelier
Description: Crystalline Oz-inspired theme. Prismatic rays, faceted glass cards, arched portal hero, magical emerald glow, and a romantic serif/sans pairing of Cormorant Garamond with Work Sans.
Version: 1.0.0
License: GPLv2 or later
Text Domain: emerald-city
*/

:root{
  --ec-dark:#022c22;
  --ec-emerald:#10b981;
  --ec-mint:#6ee7b7;
  --ec-light:#ecfdf5;
  --ec-glow:0 0 60px rgba(110,231,183,.45);
  --ec-display:"Cormorant Garamond", "Cormorant", serif;
  --ec-body:"Work Sans", system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--ec-body);color:var(--ec-dark);
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(16,185,129,.18), transparent 70%),
    radial-gradient(700px 400px at -10% 60%, rgba(110,231,183,.22), transparent 70%),
    var(--ec-light);
  line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ec-emerald);text-decoration:none;transition:color .25s}
a:hover{color:var(--ec-dark)}

/* Header */
.ec-bar{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);background:rgba(236,253,245,.72);border-bottom:1px solid rgba(16,185,129,.18)}
.ec-bar-inner{max-width:1280px;margin:0 auto;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.ec-logo{display:flex;align-items:center;gap:12px;font-family:var(--ec-display);font-size:30px;font-weight:600;font-style:italic;letter-spacing:-.01em;color:var(--ec-dark)}
.ec-gem{
  width:22px;height:26px;
  background:linear-gradient(180deg,var(--ec-mint),var(--ec-emerald));
  clip-path:polygon(50% 0,100% 35%,80% 100%,20% 100%,0 35%);
  filter:drop-shadow(0 0 10px var(--ec-mint));
}
.ec-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ec-nav a{font-size:14px;font-weight:500;letter-spacing:.02em;padding:10px 14px;color:var(--ec-dark);border-radius:8px;position:relative}
.ec-nav a:hover{background:rgba(110,231,183,.18);color:var(--ec-dark)}
.ec-nav .login{
  background:linear-gradient(135deg,var(--ec-dark),var(--ec-emerald));color:var(--ec-light);
  box-shadow:var(--ec-glow);font-weight:600;
}
.ec-nav .login:hover{transform:translateY(-1px);color:var(--ec-light);background:linear-gradient(135deg,var(--ec-emerald),var(--ec-mint))}

/* Hero - portal */
.ec-hero{position:relative;max-width:1280px;margin:0 auto;padding:80px 28px 100px;text-align:center}
.ec-portal{
  position:absolute;left:50%;top:80px;transform:translateX(-50%);
  width:min(620px,90vw);height:780px;border-radius:50% 50% 0 0 / 60% 60% 0 0;
  background:
    radial-gradient(closest-side at 50% 30%, rgba(110,231,183,.55), transparent 70%),
    linear-gradient(180deg, rgba(16,185,129,.12), transparent 70%);
  filter:blur(8px);pointer-events:none;
}
.ec-portal::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:
    conic-gradient(from 220deg at 50% 50%, transparent 0 30%, rgba(110,231,183,.4) 35%, transparent 40%, rgba(16,185,129,.3) 55%, transparent 60%);
  mix-blend-mode:screen;animation:ray 16s linear infinite;
}
@keyframes ray{to{transform:rotate(360deg)}}
.ec-hero-inner{position:relative;z-index:1}
.ec-tag{font-family:var(--ec-body);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--ec-emerald);margin-bottom:18px}
.ec-hero h1{
  font-family:var(--ec-display);font-weight:300;font-style:italic;
  font-size:clamp(48px,9vw,140px);line-height:.95;letter-spacing:-.02em;color:var(--ec-dark);margin:0 0 22px;
}
.ec-hero h1 b{
  font-style:normal;font-weight:600;
  background:linear-gradient(180deg,var(--ec-mint),var(--ec-emerald),var(--ec-dark));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.ec-hero p{font-size:19px;color:rgba(2,44,34,.72);max-width:620px;margin:0 auto 32px}
.ec-cta{
  display:inline-flex;align-items:center;gap:14px;padding:18px 32px;border-radius:999px;
  background:linear-gradient(135deg,var(--ec-dark),var(--ec-emerald));color:var(--ec-light);
  font-weight:600;letter-spacing:.04em;box-shadow:var(--ec-glow);
}
.ec-cta:hover{transform:translateY(-2px);color:var(--ec-light);box-shadow:0 0 80px rgba(110,231,183,.7)}

/* Crumbs */
.ec-crumbs{max-width:1280px;margin:0 auto;padding:8px 28px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(2,44,34,.6)}
.ec-crumbs a{color:var(--ec-emerald)}
.ec-crumbs span{margin:0 10px;color:var(--ec-mint)}

/* Layout */
.ec-shell{max-width:1280px;margin:0 auto;padding:40px 28px 80px;display:grid;grid-template-columns:1fr 320px;gap:48px}
@media (max-width:980px){.ec-shell{grid-template-columns:1fr}}
.ec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media (max-width:720px){.ec-grid{grid-template-columns:1fr}}

/* Faceted glass cards */
.ec-card{
  position:relative;border-radius:24px;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(236,253,245,.6));
  border:1px solid rgba(16,185,129,.18);
  box-shadow:0 30px 60px -34px rgba(2,44,34,.25), inset 0 1px 0 rgba(255,255,255,.7);
  backdrop-filter:blur(8px);transition:transform .35s, box-shadow .35s;
}
.ec-card:hover{transform:translateY(-4px);box-shadow:0 40px 80px -28px rgba(16,185,129,.4)}
.ec-card::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(110,231,183,.18), transparent 40%);
}
.ec-thumb{display:block;aspect-ratio:5/3;overflow:hidden;background:linear-gradient(135deg,var(--ec-dark),var(--ec-emerald))}
.ec-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.ec-card:hover .ec-thumb img{transform:scale(1.06)}
.ec-card-body{padding:24px 28px 28px;position:relative}
.ec-cat{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ec-emerald);font-weight:600}
.ec-card h2{font-family:var(--ec-display);font-weight:500;font-size:30px;line-height:1.1;letter-spacing:-.01em;margin:8px 0 12px}
.ec-card h2 a{color:var(--ec-dark)}
.ec-card h2 a:hover{color:var(--ec-emerald)}
.ec-card p{margin:0;color:rgba(2,44,34,.7);font-size:15px}
.ec-meta-line{display:flex;justify-content:space-between;margin-top:16px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(2,44,34,.55)}

/* Sidebar */
.ec-side .widget{
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(236,253,245,.7));
  border:1px solid rgba(16,185,129,.16);border-radius:20px;padding:24px;margin-bottom:22px;
  backdrop-filter:blur(8px);
}
.ec-side h3{font-family:var(--ec-display);font-weight:500;font-style:italic;font-size:24px;color:var(--ec-dark);margin:0 0 12px}
.ec-side ul{list-style:none;padding:0;margin:0}
.ec-side li{padding:8px 0;border-bottom:1px dashed rgba(16,185,129,.18);font-size:14px}
.ec-side li:last-child{border-bottom:0}
.ec-side a{color:var(--ec-dark)}
.ec-side a:hover{color:var(--ec-emerald)}

/* Article */
.ec-article{max-width:780px;margin:0 auto;padding:60px 28px 30px}
.ec-article header{text-align:center;margin-bottom:30px}
.ec-article .stamp{display:inline-block;padding:6px 14px;border-radius:999px;background:rgba(110,231,183,.3);color:var(--ec-dark);font-size:11px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:16px}
.ec-article h1{font-family:var(--ec-display);font-weight:400;font-size:clamp(40px,6vw,72px);line-height:1.05;letter-spacing:-.02em;margin:0}
.ec-article .meta{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:rgba(2,44,34,.6);margin-top:14px}
.ec-article .feat{margin:30px 0;border-radius:24px;overflow:hidden;box-shadow:var(--ec-glow)}
.ec-article .body{font-size:18px;line-height:1.85;color:rgba(2,44,34,.88)}
.ec-article .body h2,.ec-article .body h3{font-family:var(--ec-display);font-weight:500;color:var(--ec-dark)}
.ec-article .body blockquote{border-left:3px solid var(--ec-emerald);padding:14px 22px;margin:28px 0;background:rgba(110,231,183,.18);border-radius:0 16px 16px 0;font-family:var(--ec-display);font-style:italic;font-size:22px}

/* Related */
.ec-related{max-width:1280px;margin:0 auto;padding:30px 28px 80px}
.ec-related h3{font-family:var(--ec-display);font-style:italic;font-weight:500;font-size:36px;text-align:center;color:var(--ec-dark);margin:0 0 30px}

/* Pager */
.ec-pager{display:flex;justify-content:center;gap:8px;margin:30px 0}
.ec-pager a, .ec-pager span{padding:10px 16px;border-radius:999px;background:#fff;border:1px solid rgba(16,185,129,.2);font-size:14px;color:var(--ec-dark)}
.ec-pager .current{background:var(--ec-dark);color:var(--ec-light);border-color:var(--ec-dark)}

/* 404 */
.ec-404{max-width:880px;margin:0 auto;padding:140px 28px;text-align:center;position:relative}
.ec-404 .big{font-family:var(--ec-display);font-style:italic;font-weight:300;font-size:clamp(120px,22vw,260px);line-height:.9;letter-spacing:-.04em;background:linear-gradient(180deg,var(--ec-mint),var(--ec-emerald),var(--ec-dark));-webkit-background-clip:text;background-clip:text;color:transparent}

/* Comments */
.ec-comments{max-width:780px;margin:0 auto;padding:30px 28px 80px}
.ec-comments h3{font-family:var(--ec-display);font-weight:500;font-style:italic;font-size:32px}
.ec-comments ol{list-style:none;padding:0}
.ec-comments li{background:#fff;border:1px solid rgba(16,185,129,.18);border-radius:18px;padding:18px;margin-bottom:14px}
.ec-comments textarea, .ec-comments input[type="text"], .ec-comments input[type="email"], .ec-comments input[type="url"]{width:100%;padding:14px 16px;border-radius:12px;border:1px solid rgba(16,185,129,.2);background:#fff;font-family:var(--ec-body)}
.ec-comments .submit input{background:linear-gradient(135deg,var(--ec-dark),var(--ec-emerald));color:var(--ec-light);border:0;padding:14px 26px;border-radius:999px;font-weight:600;letter-spacing:.04em;cursor:pointer;box-shadow:var(--ec-glow)}

/* Footer */
.ec-foot{background:linear-gradient(180deg,#01160f,var(--ec-dark));color:var(--ec-light);margin-top:40px;position:relative;overflow:hidden}
.ec-foot::before{content:"";position:absolute;inset:0;background:radial-gradient(closest-side at 50% 0%, rgba(110,231,183,.18), transparent 70%);pointer-events:none}
.ec-foot-inner{max-width:1280px;margin:0 auto;padding:80px 28px 30px;display:grid;grid-template-columns:repeat(4,1fr);gap:40px;position:relative}
@media (max-width:880px){.ec-foot-inner{grid-template-columns:repeat(2,1fr)}}
.ec-foot h4{font-family:var(--ec-display);font-style:italic;font-weight:500;font-size:22px;color:var(--ec-mint);margin:0 0 14px}
.ec-foot ul{list-style:none;padding:0;margin:0}
.ec-foot li{padding:5px 0;font-size:14px}
.ec-foot a{color:rgba(236,253,245,.78)}
.ec-foot a:hover{color:var(--ec-mint)}
.ec-foot-bottom{border-top:1px solid rgba(110,231,183,.16);text-align:center;padding:22px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(236,253,245,.55);position:relative}
