/*
Theme Name: Lilac Dreams
Author: Studio Vesper
Description: A dreamy, ethereal WordPress theme cast in lavender mists, deep violet shadows and lilac haze. Floating elements, gradient meshes and weightless typography for editorial fantasies and luminous storytelling.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: lilac-dreams
*/

:root{
  --mist:#faf5ff;
  --violet:#7c3aed;
  --lilac:#c084fc;
  --night:#1e1b4b;
  --pearl:#ffffff;
  --soft:#ede9fe;
  --pink:#fbcfe8;
  --shadow:0 30px 60px -30px rgba(124,58,237,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Nunito Sans',sans-serif;
  background:var(--mist);
  color:var(--night);
  line-height:1.7;
  overflow-x:hidden;
  background-image:
    radial-gradient(ellipse at 0% 0%, rgba(192,132,252,.32) 0, transparent 50%),
    radial-gradient(ellipse at 100% 0%, rgba(251,207,232,.28) 0, transparent 45%),
    radial-gradient(ellipse at 50% 100%, rgba(124,58,237,.18) 0, transparent 55%);
  background-attachment:fixed;
}

h1,h2,h3,h4{font-family:'Dancing Script',cursive;color:var(--night);font-weight:700;letter-spacing:0;line-height:1.15}
h1{font-size:clamp(3rem,6vw,5.4rem)}
h2{font-size:clamp(2.2rem,4vw,3.4rem)}
h5,h6{font-family:'Nunito Sans',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.25em}
a{color:var(--violet);text-decoration:none;transition:.3s}
a:hover{color:var(--lilac)}
img{max-width:100%;height:auto;display:block;border-radius:24px}
.container{max-width:1200px;margin:0 auto;padding:0 28px}

/* floating bubbles bg */
body::before, body::after{
  content:"";position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:-1;
  animation:drift 18s ease-in-out infinite;
}
body::before{width:380px;height:380px;background:radial-gradient(circle,#c084fc 0,transparent 70%);top:18%;left:-120px;}
body::after{width:460px;height:460px;background:radial-gradient(circle,#fbcfe8 0,transparent 70%);bottom:8%;right:-150px;animation-delay:-9s;}
@keyframes drift{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-30px) translateX(20px)}}

/* HEADER */
.site-header{
  padding:24px 0;position:sticky;top:0;z-index:50;
  backdrop-filter:blur(18px);
  background:rgba(250,245,255,.65);
  border-bottom:1px solid rgba(192,132,252,.25);
}
.header-bar{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.brand{font-family:'Dancing Script',cursive;font-size:2.4rem;color:var(--night);font-weight:700;}
.brand em{color:var(--violet);font-style:normal}

.primary-nav ul{list-style:none;display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.primary-nav a{
  padding:10px 18px;border-radius:999px;color:var(--night);font-weight:600;font-size:.92rem;
}
.primary-nav a:hover{background:rgba(192,132,252,.18);color:var(--violet)}
.primary-nav .nav-cta a{
  background:linear-gradient(135deg,var(--violet),var(--lilac));color:#fff;
  box-shadow:0 12px 28px -12px rgba(124,58,237,.7);
}
.primary-nav .nav-cta a:hover{filter:brightness(1.08);color:#fff}

/* HERO */
.hero{padding:90px 0 120px;text-align:center;position:relative}
.hero .pill{
  display:inline-block;padding:8px 18px;border-radius:999px;
  background:rgba(255,255,255,.7);border:1px solid rgba(192,132,252,.5);
  color:var(--violet);font-weight:700;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:24px;
  backdrop-filter:blur(8px);
}
.hero h1{margin:0 auto;max-width:14ch;background:linear-gradient(135deg,#1e1b4b 0%,#7c3aed 50%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{max-width:60ch;margin:24px auto 36px;font-size:1.18rem;color:#4c1d95}
.btn-row{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}

.btn{
  display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:999px;
  font-weight:700;letter-spacing:.04em;font-size:.95rem;cursor:pointer;border:0;transition:.3s;
}
.btn-primary{background:linear-gradient(135deg,var(--violet),var(--lilac));color:#fff;box-shadow:0 18px 36px -16px rgba(124,58,237,.7)}
.btn-primary:hover{transform:translateY(-3px);color:#fff;box-shadow:0 24px 50px -18px rgba(124,58,237,.85)}
.btn-ghost{background:rgba(255,255,255,.8);color:var(--night);border:1px solid rgba(124,58,237,.3)}
.btn-ghost:hover{background:#fff;color:var(--violet)}

.hero-floats{position:absolute;inset:0;pointer-events:none;z-index:-1}
.float{position:absolute;border-radius:50%;background:linear-gradient(135deg,#c084fc,#fbcfe8);opacity:.6;animation:float 8s ease-in-out infinite}
.float.f1{width:60px;height:60px;top:14%;left:14%}
.float.f2{width:90px;height:90px;top:20%;right:12%;animation-delay:-3s;background:linear-gradient(135deg,#7c3aed,#c084fc)}
.float.f3{width:36px;height:36px;bottom:24%;left:22%;animation-delay:-5s}
.float.f4{width:120px;height:120px;bottom:10%;right:18%;animation-delay:-2s;opacity:.4}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-22px)}}

/* SECTIONS */
.section{padding:90px 0;position:relative}
.section-eyebrow{text-align:center;color:var(--violet);font-weight:800;letter-spacing:.4em;text-transform:uppercase;font-size:.78rem;margin-bottom:6px}
.section-title{text-align:center;margin-bottom:50px}

.layout{display:grid;grid-template-columns:1fr 320px;gap:50px;align-items:flex-start}
.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}

.post-card{
  background:rgba(255,255,255,.72);backdrop-filter:blur(14px);
  border-radius:32px;border:1px solid rgba(192,132,252,.3);
  padding:18px;box-shadow:var(--shadow);transition:.4s;overflow:hidden;position:relative;
}
.post-card:hover{transform:translateY(-8px) rotate(-.4deg);box-shadow:0 40px 80px -30px rgba(124,58,237,.45)}
.post-card::before{
  content:"";position:absolute;top:-50%;right:-30%;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(192,132,252,.4) 0,transparent 70%);
  pointer-events:none;
}
.post-card .thumb{aspect-ratio:16/10;overflow:hidden;border-radius:22px;background:linear-gradient(135deg,#c084fc,#fbcfe8)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:.5s}
.post-card:hover .thumb img{transform:scale(1.07)}
.post-card .body{padding:22px 14px 12px;position:relative;z-index:2}
.post-card h3{font-family:'Dancing Script',cursive;font-size:1.85rem;margin-bottom:8px;line-height:1.1}
.post-card h3 a{color:var(--night)}
.post-card h3 a:hover{color:var(--violet)}
.post-card .meta{font-size:.75rem;color:var(--violet);font-weight:800;text-transform:uppercase;letter-spacing:.25em;margin-bottom:10px}
.post-card .excerpt{color:#4c1d95;font-size:.95rem}

.no-thumb{
  display:grid;place-items:center;width:100%;height:100%;color:#fff;
  font-family:'Dancing Script',cursive;font-size:2.2rem;
}

/* SIDEBAR */
.sidebar{display:flex;flex-direction:column;gap:24px}
.widget{
  background:rgba(255,255,255,.7);backdrop-filter:blur(14px);
  border:1px solid rgba(192,132,252,.3);border-radius:24px;padding:26px 24px;
}
.widget h4{font-family:'Dancing Script',cursive;font-size:1.7rem;margin-bottom:14px;color:var(--violet)}
.widget ul{list-style:none}
.widget li{padding:8px 0;border-bottom:1px dashed rgba(124,58,237,.2);font-size:.95rem}
.widget li:last-child{border-bottom:0}
.widget a{color:var(--night)}
.widget a:hover{color:var(--violet)}

/* BREADCRUMB */
.breadcrumb{padding:18px 0;font-size:.85rem;color:#4c1d95}
.breadcrumb a{color:var(--violet)}
.breadcrumb span{color:var(--night);font-weight:700}

/* SINGLE */
.single-article{
  background:rgba(255,255,255,.78);backdrop-filter:blur(14px);
  border-radius:32px;padding:54px 60px;box-shadow:var(--shadow);
  border:1px solid rgba(192,132,252,.3);margin-top:40px;
}
.single-article h1{margin-bottom:14px;background:linear-gradient(135deg,#1e1b4b,#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}
.single-article .meta{color:var(--violet);text-transform:uppercase;font-weight:800;letter-spacing:.25em;font-size:.78rem;margin-bottom:24px}
.single-article .featured{margin:0 0 28px;border-radius:24px;overflow:hidden;aspect-ratio:21/9}
.single-article .featured img{width:100%;height:100%;object-fit:cover;border-radius:0}
.single-article .content p{margin-bottom:16px}
.single-article .content blockquote{border-left:4px solid var(--lilac);background:rgba(192,132,252,.12);padding:14px 22px;border-radius:0 18px 18px 0;font-style:italic;margin:22px 0;color:var(--violet)}

.related{margin-top:60px}
.related h3{font-family:'Dancing Script',cursive;font-size:2.4rem;text-align:center;margin-bottom:24px}

/* PAGINATION */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px;flex-wrap:wrap}
.pagination a,.pagination span{padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.7);color:var(--violet);font-weight:700;border:1px solid rgba(124,58,237,.25);font-size:.9rem}
.pagination .current{background:linear-gradient(135deg,var(--violet),var(--lilac));color:#fff;border-color:transparent}

/* COMMENTS */
.comments-area{margin-top:50px;background:rgba(255,255,255,.78);padding:38px 40px;border-radius:28px;border:1px solid rgba(192,132,252,.3)}
.comments-area h3{font-family:'Dancing Script',cursive;font-size:2rem;margin-bottom:18px;color:var(--violet)}
.comment-list{list-style:none}
.comment{padding:16px 0;border-bottom:1px dashed rgba(124,58,237,.18)}
.comment-meta{font-size:.78rem;color:var(--violet);font-weight:800;letter-spacing:.2em;text-transform:uppercase}
.comment-form input,.comment-form textarea{
  width:100%;padding:14px 16px;border-radius:16px;border:1px solid rgba(124,58,237,.3);
  background:rgba(255,255,255,.85);font-family:inherit;margin-bottom:14px;
}
.comment-form input:focus,.comment-form textarea:focus{outline:2px solid var(--lilac);border-color:var(--lilac)}
.comment-form .submit{background:linear-gradient(135deg,var(--violet),var(--lilac));color:#fff;border:0;padding:12px 28px;border-radius:999px;cursor:pointer;font-weight:700;letter-spacing:.05em}

/* 404 */
.page-404{padding:140px 0;text-align:center}
.page-404 .star{font-size:6rem;color:var(--lilac);animation:drift 6s ease-in-out infinite;display:inline-block}
.page-404 h1{font-size:7rem;background:linear-gradient(135deg,#1e1b4b,#c084fc);-webkit-background-clip:text;background-clip:text;color:transparent}

/* FOOTER */
.site-footer{
  margin-top:80px;padding:80px 0 30px;color:#fff;
  background:linear-gradient(135deg,#1e1b4b 0%,#4c1d95 50%,#7c3aed 100%);
  border-radius:60px 60px 0 0;position:relative;overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;top:-50px;left:50%;transform:translateX(-50%);
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(192,132,252,.45) 0,transparent 70%);
  pointer-events:none;
}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;position:relative;z-index:2}
.footer-col h5{color:var(--lilac);font-size:.85rem;margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col a{color:#ede9fe;font-size:.92rem}
.footer-col a:hover{color:#fff}
.footer-bottom{margin-top:60px;padding-top:24px;border-top:1px solid rgba(255,255,255,.18);text-align:center;font-size:.85rem;color:var(--lilac);letter-spacing:.1em}

@media(max-width:980px){
  .layout{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .single-article{padding:34px 24px}
  .site-footer{border-radius:36px 36px 0 0}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .primary-nav ul{justify-content:center}
}
