/* ============================================================
   udhsri-addon.css  — loaded AFTER style.css & udhsri-pages.css
   Only adds new rules. Never conflicts with existing CSS.
   ============================================================ */

/* ── Animated floating shapes in page-header (breadcrumb area) ── */
/* Adds floating circles — exactly like master template preview   */
.page-header { overflow: hidden; }

.ph-shape {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    will-change: transform;
    animation: phFloat 9s ease-in-out infinite;
}
.ph-shape.s1 { width:320px;height:320px;background:rgba(255,255,255,0.05);top:-80px;right:-70px;animation-delay:0s; }
.ph-shape.s2 { width:200px;height:200px;background:rgba(255,255,255,0.04);bottom:-55px;left:8%;animation-delay:-3.5s;animation-duration:11s; }
.ph-shape.s3 { width:120px;height:120px;background:rgba(255,255,255,0.06);top:35%;right:20%;animation-delay:-6s;animation-duration:7s; }

@keyframes phFloat {
    0%,100% { transform:translate(0,0) rotate(0deg); }
    33%      { transform:translate(10px,-14px) rotate(5deg); }
    66%      { transform:translate(-8px,8px) rotate(-3deg); }
}

/* ── Hero Carousel enhancements ───────────────────────────── */
.carousel-bg { position:relative; overflow:hidden; }

/* Floating bubbles inside each slide — CSS only, no JS */
.cs-bubble {
    position:absolute; border-radius:50%;
    background:rgba(255,255,255,0.10);
    pointer-events:none; will-change:transform;
    animation:phFloat 10s ease-in-out infinite;
}
.cs-bubble.b1 { width:420px;height:420px;top:-130px;right:-90px;animation-delay:0s; }
.cs-bubble.b2 { width:260px;height:260px;bottom:-80px;left:-60px;animation-delay:-4s;animation-duration:13s; }
.cs-bubble.b3 { width:150px;height:150px;top:25%;left:10%;animation-delay:-7s;animation-duration:8s; }

/* Slide text staggered entrance */
.slide-t1 { animation:slideUp .7s .1s ease-out both; }
.slide-t2 { animation:slideUp .7s .3s ease-out both; }
.slide-t3 { animation:slideUp .7s .5s ease-out both; }
@keyframes slideUp {
    from { opacity:0; transform:translateY(35px); }
    to   { opacity:1; transform:translateY(0); }
}

/* Frosted pill badge in carousel */
.slide-badge {
    display:inline-block;
    background:rgba(255,255,255,0.18);
    color:#fff; border:1px solid rgba(255,255,255,0.35);
    border-radius:50px; padding:6px 20px;
    font-size:.88rem; font-weight:500;
    backdrop-filter:blur(4px);
    margin-bottom:16px;
}

/* ── Section header helpers ────────────────────────────────── */
.sec-badge {
    display:inline-block;
    background:rgba(102,126,234,.1); color:#667eea;
    border:1px solid rgba(102,126,234,.25);
    border-radius:50px; padding:5px 18px;
    font-size:.82rem; font-weight:600; margin-bottom:10px;
}
.sec-divider {
    width:55px; height:4px;
    background:linear-gradient(135deg,#667eea,#764ba2);
    border-radius:2px; margin:10px auto 0;
}
.sec-divider.left { margin-left:0; }

/* ── HUB PAGE — hero ───────────────────────────────────────── */
.hub-hero {
    padding:105px 0 60px;
    position:relative; overflow:hidden; color:#fff;
}
.hub-hero.hub-festivals  { background:linear-gradient(135deg,#1a1a2e 0%,#3d0044 55%,#6b0069 100%); }
.hub-hero.hub-idays      { background:linear-gradient(135deg,#1a1a2e 0%,#00300f 55%,#005218 100%); }
.hub-hero h1             { font-size:clamp(2rem,5vw,3.2rem); font-weight:800; }
.hub-hero .breadcrumb-item a          { color:rgba(255,255,255,.7); text-decoration:none; }
.hub-hero .breadcrumb-item.active     { color:rgba(255,255,255,.9); }
.hub-hero .breadcrumb-item+.breadcrumb-item::before { color:rgba(255,255,255,.4); }

/* Search box */
.hub-search {
    background:#fff; border-radius:50px;
    padding:6px 6px 6px 22px;
    display:flex; align-items:center;
    max-width:520px;
    box-shadow:0 8px 30px rgba(0,0,0,.15);
}
.hub-search input  { border:none;outline:none;flex:1;font-size:.93rem;background:transparent;font-family:'Poppins',sans-serif;color:#333; }
.hub-search input::placeholder { color:#999; }
.hub-search button {
    background:linear-gradient(135deg,#667eea,#764ba2);
    color:#fff;border:none;border-radius:50px;
    padding:9px 22px;font-weight:600;font-family:'Poppins',sans-serif;
    font-size:.88rem;cursor:pointer;transition:all .3s;white-space:nowrap;
}
.hub-search button:hover { opacity:.9;transform:scale(1.02); }

/* Stats strip */
.hub-strip { padding:22px 0; color:#fff; }
.hub-strip.hs-festivals { background:linear-gradient(135deg,#667eea,#764ba2); }
.hub-strip.hs-idays     { background:linear-gradient(135deg,#27ae60,#16a085); }
.hub-strip-stat { text-align:center; }
.hub-strip-stat h3 { font-size:2rem;font-weight:800;margin:0; }
.hub-strip-stat p  { font-size:.85rem;opacity:.85;margin:0; }

/* ── Category cards ────────────────────────────────────────── */
.cat-card {
    background:#fff; border-radius:14px; overflow:hidden;
    box-shadow:0 4px 16px rgba(0,0,0,.07);
    transition:all .32s ease;
    border:1px solid rgba(0,0,0,.07);
    height:100%; display:block;
    text-decoration:none; color:inherit;
}
.cat-card:hover {
    transform:translateY(-7px);
    box-shadow:0 14px 36px rgba(102,126,234,.22);
    border-color:rgba(102,126,234,.3);
    color:inherit; text-decoration:none;
}
.cat-icon {
    height:118px; display:flex;
    align-items:center; justify-content:center; font-size:3.2rem;
}
.cat-body { padding:16px; }
.cat-body h5 { font-weight:700;font-size:.96rem;margin-bottom:4px;color:#1a1a2e; }
.cat-body p  { font-size:.81rem;color:#666;margin:0 0 9px;line-height:1.5; }
.cat-count {
    display:inline-block; font-size:.75rem;font-weight:600;
    padding:3px 12px;border-radius:20px;
    background:rgba(102,126,234,.1);color:#667eea;
    border:1px solid rgba(102,126,234,.2);
}

/* Festival icon colours */
.ic-diwali    {background:linear-gradient(135deg,#ff6b35,#f7b731);}
.ic-holi      {background:linear-gradient(135deg,#e74c3c,#9b59b6);}
.ic-eid       {background:linear-gradient(135deg,#1abc9c,#16a085);}
.ic-christmas {background:linear-gradient(135deg,#c0392b,#27ae60);}
.ic-navratri  {background:linear-gradient(135deg,#e74c3c,#e67e22);}
.ic-ganesh    {background:linear-gradient(135deg,#f39c12,#e67e22);}
.ic-dussehra  {background:linear-gradient(135deg,#e74c3c,#f39c12);}
.ic-durga     {background:linear-gradient(135deg,#c0392b,#9b59b6);}
.ic-lohri     {background:linear-gradient(135deg,#e67e22,#f1c40f);}
.ic-sankranti {background:linear-gradient(135deg,#f39c12,#2ecc71);}
.ic-janmash   {background:linear-gradient(135deg,#2980b9,#8e44ad);}
.ic-baisakhi  {background:linear-gradient(135deg,#f39c12,#27ae60);}
.ic-onam      {background:linear-gradient(135deg,#27ae60,#f1c40f);}
.ic-pongal    {background:linear-gradient(135deg,#f1c40f,#27ae60);}
.ic-gurupurab {background:linear-gradient(135deg,#f39c12,#e74c3c);}
.ic-newyear   {background:linear-gradient(135deg,#667eea,#764ba2);}

/* Important-days icon colours */
.ic-republic    {background:linear-gradient(135deg,#e74c3c,#3498db);}
.ic-independence{background:linear-gradient(135deg,#27ae60,#f39c12);}
.ic-gandhi      {background:linear-gradient(135deg,#16a085,#f39c12);}
.ic-childrens   {background:linear-gradient(135deg,#3498db,#e74c3c);}
.ic-teachers    {background:linear-gradient(135deg,#8e44ad,#3498db);}
.ic-doctors     {background:linear-gradient(135deg,#e74c3c,#c0392b);}
.ic-army        {background:linear-gradient(135deg,#2ecc71,#2980b9);}
.ic-constitution{background:linear-gradient(135deg,#2980b9,#8e44ad);}
.ic-womens      {background:linear-gradient(135deg,#e91e63,#9c27b0);}
.ic-mothers     {background:linear-gradient(135deg,#e91e63,#ff5722);}
.ic-fathers     {background:linear-gradient(135deg,#2196f3,#1976d2);}
.ic-environment {background:linear-gradient(135deg,#4caf50,#8bc34a);}
.ic-yoga        {background:linear-gradient(135deg,#ff9800,#ff5722);}
.ic-health      {background:linear-gradient(135deg,#f44336,#e91e63);}
.ic-earth       {background:linear-gradient(135deg,#4caf50,#2196f3);}
.ic-valentines  {background:linear-gradient(135deg,#e91e63,#f44336);}

/* Tag pills */
.tag-pill {
    display:inline-block; padding:4px 13px; border-radius:20px;
    font-size:.79rem; font-weight:500;
    background:rgba(102,126,234,.08); color:#667eea;
    border:1px solid rgba(102,126,234,.2);
    margin:3px 2px; text-decoration:none; transition:all .25s;
}
.tag-pill:hover {
    background:linear-gradient(135deg,#667eea,#764ba2);
    color:#fff; border-color:transparent; text-decoration:none;
}

/* ── Creatives promo block (homepage) ──────────────────────── */
.creatives-promo { background:linear-gradient(135deg,#1a1a2e 0%,#16213e 60%,#6b0069 100%); padding:70px 0; }
.promo-pill {
    display:inline-block; background:rgba(240,147,251,.15);
    color:#f093fb; border:1px solid rgba(240,147,251,.3);
    border-radius:50px; padding:5px 18px;
    font-size:.85rem; font-weight:500; margin-bottom:16px;
}
.promo-box {
    border-radius:10px; height:108px;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    border:1px solid rgba(255,255,255,.15); color:#fff;
    font-size:2rem; transition:all .3s;
}
.promo-box small { font-size:.79rem; font-weight:500; margin-top:4px; }
.promo-box:hover { transform:translateY(-3px); border-color:rgba(255,255,255,.35); }

/* ── Facebook posts section ────────────────────────────────── */
.fb-posts-section { background:#eef2ff; padding:70px 0; }
.fb-embed-card {
    background:#fff; border-radius:12px;
    box-shadow:0 4px 18px rgba(0,0,0,.08);
    padding:14px; border:1px solid #dde2f0;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    min-height:280px;
}
.btn-fb-follow {
    display:inline-flex; align-items:center; gap:8px;
    background:#1877F2; color:#fff; padding:11px 26px;
    border-radius:50px; font-weight:600;
    text-decoration:none; transition:all .3s; font-size:.95rem;
}
.btn-fb-follow:hover { background:#1260cc;color:#fff;text-decoration:none;transform:translateY(-2px); }

/* ── Master template — design page ─────────────────────────── */
.design-hero {
    background:linear-gradient(135deg,#1a1a2e 0%,#16213e 55%,#0f3460 100%);
    padding:95px 0 55px; position:relative; overflow:hidden; color:#fff;
}
.design-hero h1 { font-size:clamp(1.8rem,4vw,2.7rem); font-weight:800; }
.design-hero .breadcrumb-item a       { color:rgba(255,255,255,.7);text-decoration:none; }
.design-hero .breadcrumb-item.active  { color:rgba(255,255,255,.9); }
.design-hero .breadcrumb-item+.breadcrumb-item::before { color:rgba(255,255,255,.4); }

.design-showcase { background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 5px 22px rgba(0,0,0,.1);border:1px solid rgba(0,0,0,.07);margin-bottom:22px; }
.design-showcase img { width:100%;display:block;transition:transform .4s ease; }
.design-showcase:hover img { transform:scale(1.02); }
.design-showcase-body { padding:22px; }
.design-showcase-body h2 { font-size:1.2rem;font-weight:700;margin-bottom:8px;color:#1a1a2e; }

.btn-dl {
    display:inline-flex;align-items:center;gap:7px;
    background:linear-gradient(135deg,#667eea,#764ba2);
    color:#fff;border:none;border-radius:50px;
    padding:10px 26px;font-size:.9rem;font-weight:600;
    text-decoration:none;transition:all .3s;
    font-family:'Poppins',sans-serif;cursor:pointer;
}
.btn-dl:hover { color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 8px 20px rgba(102,126,234,.4); }

.share-bar { background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:18px 22px;color:#fff;margin-bottom:22px; }
.share-bar h6 { font-size:.9rem;margin-bottom:12px;opacity:.9; }
.sbtn { display:inline-flex;align-items:center;gap:5px;padding:7px 16px;border-radius:50px;font-size:.8rem;font-weight:600;text-decoration:none;margin:3px;transition:transform .2s;color:#fff; }
.sbtn:hover { transform:scale(1.05);color:#fff;text-decoration:none; }
.sbtn-wa{background:#25D366;} .sbtn-fb{background:#1877F2;}
.sbtn-tw{background:#000;}    .sbtn-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);}

.seo-content-box { background:#fff;border-radius:12px;padding:26px;box-shadow:0 4px 14px rgba(0,0,0,.07);border:1px solid rgba(0,0,0,.07);margin-bottom:22px; }
.seo-content-box h2 { font-size:1.3rem;color:#1a1a2e;margin-bottom:12px; }
.seo-content-box p  { color:#555;line-height:1.8;font-size:.92rem; }

.info-card { background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 14px rgba(0,0,0,.07);border:1px solid rgba(0,0,0,.07);margin-bottom:18px; }
.info-card h5 { font-size:.97rem;font-weight:700;margin-bottom:14px;color:#1a1a2e; }
.info-tbl { width:100%; }
.info-tbl td { padding:7px 0;font-size:.86rem;border-bottom:1px solid #f0f0f0; }
.info-tbl td:first-child { color:#888;width:42%; }
.info-tbl td:last-child  { font-weight:600;color:#333; }

.related-card { background:#fff;border-radius:11px;overflow:hidden;box-shadow:0 3px 12px rgba(0,0,0,.08);transition:all .3s;border:1px solid rgba(0,0,0,.06);text-decoration:none;display:block;color:inherit; }
.related-card:hover { transform:translateY(-5px);box-shadow:0 10px 28px rgba(102,126,234,.18);color:inherit;text-decoration:none; }
.related-card img { width:100%;height:155px;object-fit:cover;display:block; }
.related-card-body { padding:11px; }
.related-card-body p { font-size:.82rem;font-weight:600;margin:0 0 7px;line-height:1.4;color:#333; }

/* ── Design Thumbnail Card (festival listing pages) ─────────── */
.design-thumb-card {
    display: block; text-decoration: none; color: inherit;
    background: #fff; border-radius: 12px; overflow: hidden;
    box-shadow: 0 3px 14px rgba(0,0,0,.08);
    border: 1px solid rgba(0,0,0,.07); transition: all .3s ease;
}
.design-thumb-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 32px rgba(102,126,234,.22);
    border-color: rgba(102,126,234,.3); color: inherit; text-decoration: none;
}
.design-thumb-img {
    position: relative; overflow: hidden;
    aspect-ratio: 1 / 1; background: #f5f5f5;
}
.design-thumb-img img { width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease; }
.design-thumb-card:hover .design-thumb-img img { transform: scale(1.06); }
.design-thumb-overlay {
    position: absolute; inset: 0;
    background: rgba(102,126,234,.82);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity .3s ease;
}
.design-thumb-card:hover .design-thumb-overlay { opacity: 1; }
.btn-dl-sm {
    background: #fff; color: #667eea; border-radius: 50px;
    padding: 7px 18px; font-size: .8rem; font-weight: 700; white-space: nowrap;
}
.design-thumb-body {
    padding: 10px 12px; display: flex;
    justify-content: space-between; align-items: center; gap: 6px;
}
.design-thumb-body p { font-size:.8rem;font-weight:600;color:#333;margin:0;line-height:1.35;flex:1; }
.design-thumb-tag { display:inline-flex;align-items:center;font-size:.72rem;font-weight:600;color:#27ae60;white-space:nowrap;flex-shrink:0; }

/* ── Fix: service-card height:100% override for sidebar/content use ── */
/* style.css sets height:100% on .service-card for the services grid.  */
/* In sidebar and SEO content blocks, cards must be auto height.        */
.seo-content-section .service-card,
.sidebar-card,
.hub-sidebar .service-card,
.col-lg-5 .service-card,
.col-lg-4 .service-card {
    height: auto !important;
}

/* Fix: row alignment — prevent stretch causing cards to exceed content */
.seo-content-section .row,
.design-content-row {
    align-items: flex-start !important;
}

/* ── Responsive tweaks ─────────────────────────────────────── */
@media(max-width:768px){
    .hub-hero{padding:80px 0 42px;}
    .cat-icon{height:95px;font-size:2.7rem;}
    .hub-strip-stat h3{font-size:1.7rem;}
    .design-hero{padding:80px 0 42px;}
    .hub-search{max-width:100%;}
}
@media(max-width:576px){
    .hub-hero h1{font-size:1.9rem;}
    .slide-badge{font-size:.78rem;}
}
