/*
Theme Name: Sommerville — Quiet Light
Theme URI: https://example.com/sommerville
Author: Your Studio
Author URI: https://example.com
Description: A quiet, dignified funeral-home theme with a cinematic hero, obituary grid, facilities showcase and grief-resource cards. Converted from the "Sommerville Home" static design.
Version: 1.2.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: sommerville
Tags: custom-colors, custom-menu, featured-images, full-width-template, translation-ready, elementor
*/

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#f7f3ec;font-family:'Spectral',Georgia,serif;-webkit-font-smoothing:antialiased;color:#2a2320}
a{cursor:pointer}
img{max-width:100%;display:block}
.screen-reader-text{position:absolute!important;left:-9999px;top:-9999px}
.container{max-width:1040px;margin:0 auto}

@keyframes somBob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

/* ===== Header / Nav ===== */
.som-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:15px 38px;background:rgba(247,243,236,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(42,35,32,.08)}
.som-logo{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:20px;letter-spacing:.12em;color:#5c2233;text-decoration:none}
.som-nav{display:flex;align-items:center;gap:30px;font:400 14px 'Spectral',serif}
.som-nav ul{list-style:none;display:flex;gap:30px;margin:0;padding:0}
.som-nav a{color:#4a423c;text-decoration:none;transition:color .22s ease}
.som-nav a:hover,.som-nav .current-menu-item>a{color:#5c2233}
.som-search{display:flex;align-items:center;gap:7px;padding:7px 13px;border:1px solid rgba(42,35,32,.16);border-radius:30px;color:#8a7d72;font:400 13px 'Spectral',serif;background:none}
.som-menu-toggle{display:none;background:none;border:0;cursor:pointer}

/* ===== Hero ===== */
.som-hero{position:relative;min-height:94vh;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.som-hero-media{position:absolute;inset:-4%;will-change:transform;transform:scale(1.12);background:radial-gradient(120% 90% at 50% 18%,#8d4a4a 0%,#5c2233 42%,#3a1320 100%);background-size:cover;background-position:center}
.som-hero-media::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(118deg,rgba(255,255,255,.05) 0 2px,transparent 2px 16px);opacity:.5}
.som-hero-media::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 50% 60%,rgba(184,136,78,.34),transparent 70%)}
.som-hero-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,18,28,.34) 0%,rgba(40,18,28,.12) 40%,rgba(40,18,28,.5) 100%);opacity:.42}
.som-hero-noise{position:absolute;inset:0;pointer-events:none;opacity:.07;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.som-hero-cap{position:relative;z-index:2;padding:0 24px;will-change:transform,opacity}
.som-eyebrow{font:500 11px 'IBM Plex Mono',monospace;letter-spacing:.42em;color:rgba(255,238,222,.78);text-transform:uppercase;margin-bottom:26px}
.som-hero-cap h1{margin:0;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(46px,7vw,92px);line-height:1.02;color:#fdf7ee;letter-spacing:-.01em}
.som-hero-cap h1 em{font-style:italic;font-weight:400;color:#e9c893}
.som-hero-cap p{margin:26px auto 0;max-width:540px;font-weight:300;font-size:clamp(17px,1.6vw,20px);line-height:1.6;color:rgba(255,243,232,.86)}
.som-hero-actions{display:flex;gap:14px;justify-content:center;margin-top:36px;flex-wrap:wrap}
.som-btn{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border-radius:34px;text-decoration:none;font:500 15px 'Spectral',serif;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,border-color .25s ease}
.som-btn-light{background:#f7f3ec;color:#5c2233}
.som-btn-light:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(0,0,0,.5)}
.som-btn-outline{background:transparent;color:#fdf7ee;border:1px solid rgba(255,243,232,.5);font-weight:400}
.som-btn-outline:hover{background:rgba(255,243,232,.12);border-color:rgba(255,243,232,.85)}
.som-scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;animation:somBob 2.4s ease-in-out infinite}
.som-scroll-cue span{font:500 9px 'IBM Plex Mono',monospace;letter-spacing:.3em;color:rgba(255,238,222,.6)}

/* ===== Dual CTA ===== */
.som-dual-cta{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(42,35,32,.1)}
.som-cta-panel{position:relative;overflow:hidden;padding:64px 52px;opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s ease}
.som-cta-panel.is-visible{opacity:1;transform:translateY(0)}
.som-cta-need{background:linear-gradient(135deg,#f3ead9,#efe3cf)}
.som-cta-plan{background:linear-gradient(135deg,#2f3a3c,#243033)}
.som-cta-orb{position:absolute;border-radius:50%;will-change:transform}
.som-cta-need .som-cta-orb{right:-30px;top:-30px;width:230px;height:230px;background:radial-gradient(circle,rgba(184,136,78,.28),transparent 70%)}
.som-cta-plan .som-cta-orb{left:-40px;bottom:-50px;width:260px;height:260px;background:radial-gradient(circle,rgba(184,136,78,.22),transparent 70%)}
.som-cta-panel .som-cta-inner{position:relative}
.som-cta-tag{font:500 10px 'IBM Plex Mono',monospace;letter-spacing:.32em;text-transform:uppercase;margin-bottom:18px}
.som-cta-need .som-cta-tag{color:#b8884e}
.som-cta-plan .som-cta-tag{color:#d8c39a}
.som-cta-panel h2{margin:0 0 14px;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:38px;line-height:1.06}
.som-cta-need h2{color:#2a2320}
.som-cta-plan h2{color:#fdf7ee}
.som-cta-panel p{margin:0 0 26px;max-width:340px;font-weight:300;font-size:16px;line-height:1.6}
.som-cta-need p{color:#6b625c}
.som-cta-plan p{color:rgba(247,243,236,.74)}
.som-btn-maroon{background:#5c2233;color:#fdf7ee}
.som-btn-maroon:hover{transform:translateY(-2px);background:#45182a}
.som-btn-gold{background:#b8884e;color:#241a10}
.som-btn-gold:hover{transform:translateY(-2px);background:#c79a5b}

/* ===== Section heads ===== */
.som-section{padding:96px 52px 88px;background:#f7f3ec}
.som-section-head{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s ease;text-align:center;margin-bottom:52px}
.som-section-head.is-visible{opacity:1;transform:translateY(0)}
.som-tag{font:500 10px 'IBM Plex Mono',monospace;letter-spacing:.34em;color:#b8884e;text-transform:uppercase;margin-bottom:14px}
.som-section-head h2{margin:0;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(36px,4.4vw,54px);line-height:1.04;color:#2a2320}

/* ===== Obituaries grid ===== */
.som-obit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;max-width:1040px;margin:0 auto}
.som-obit-card{opacity:0;transform:translateY(26px);transition:opacity .85s ease,transform .85s ease}
.som-obit-card.is-visible{opacity:1;transform:translateY(0)}
.som-obit-frame{position:relative;aspect-ratio:4/5;border-radius:12px;overflow:hidden;background:repeating-linear-gradient(135deg,#ece4d6 0 12px,#e6ddcd 12px 24px);box-shadow:0 14px 30px -18px rgba(42,35,32,.5);transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .45s ease;cursor:pointer;text-decoration:none;display:block}
.som-obit-frame:hover{transform:translateY(-8px);box-shadow:0 30px 50px -22px rgba(42,18,28,.55)}
.som-obit-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.som-obit-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(42,18,28,.62))}
.som-obit-meta{position:absolute;left:16px;right:16px;bottom:15px;color:#fdf7ee;z-index:2}
.som-obit-meta .name{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:21px;line-height:1.05}
.som-obit-meta .years{font:400 12px 'IBM Plex Mono',monospace;color:rgba(255,243,232,.74);margin-top:4px}
.som-view-all{text-align:center;margin-top:46px}
.som-btn-outline-maroon{padding:13px 30px;border:1px solid #5c2233;color:#5c2233;border-radius:32px;text-decoration:none;font:500 14px 'Spectral',serif;transition:background .25s ease,color .25s ease}
.som-btn-outline-maroon:hover{background:#5c2233;color:#fdf7ee}

/* ===== Facilities ===== */
.som-facilities{padding:0 0 6px;background:#2a2320;color:#f7f3ec}
.som-facilities-head{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s ease;padding:90px 52px 18px;text-align:center}
.som-facilities-head.is-visible{opacity:1;transform:translateY(0)}
.som-facilities-head .som-tag{color:#d8c39a}
.som-facilities-head h2{color:#fdf7ee}
.som-facilities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:40px 0 0}
.som-facility{margin:0;position:relative;height:380px;overflow:hidden}
.som-facility+.som-facility{border-left:1px solid rgba(247,243,236,.08)}
.som-facility-bg{position:absolute;inset:-12%;background:repeating-linear-gradient(135deg,#3a322c 0 14px,#332b26 14px 28px);will-change:transform;background-size:cover;background-position:center}
.som-facility::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(20,14,12,.78))}
.som-facility figcaption{position:absolute;left:30px;bottom:26px;z-index:2}
.som-facility figcaption .num{font:500 9px 'IBM Plex Mono',monospace;letter-spacing:.3em;color:#d8c39a;text-transform:uppercase;margin-bottom:7px}
.som-facility figcaption .title{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:30px;color:#fdf7ee}

/* ===== Upload band ===== */
.som-upload{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s ease;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding:46px 52px;background:linear-gradient(135deg,#b8884e,#a4763d);color:#241a10}
.som-upload.is-visible{opacity:1;transform:translateY(0)}
.som-upload h3{margin:0 0 6px;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:30px}
.som-upload p{margin:0;font-weight:300;font-size:15px;color:rgba(36,26,16,.78)}
.som-btn-dark{background:#241a10;color:#f3ead9;padding:14px 30px}
.som-btn-dark:hover{transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(36,26,16,.6)}

/* ===== Testimonial ===== */
.som-testimonial{padding:96px 52px;background:#f7f3ec;text-align:center}
.som-testimonial-inner{opacity:0;transform:translateY(22px);transition:opacity 1s ease,transform 1s ease;max-width:760px;margin:0 auto}
.som-testimonial-inner.is-visible{opacity:1;transform:translateY(0)}
.som-quote-mark{font-family:'Cormorant Garamond',serif;font-size:64px;line-height:0;color:#b8884e;height:30px;display:block}
.som-testimonial blockquote{margin:0 0 28px;font-family:'Cormorant Garamond',serif;font-weight:500;font-style:italic;font-size:clamp(26px,3.2vw,38px);line-height:1.32;color:#2a2320}
.som-testimonial cite{font:500 13px 'IBM Plex Mono',monospace;letter-spacing:.06em;color:#6b625c;font-style:normal}

/* ===== Resources ===== */
.som-resources{padding:0 52px 90px;background:#f7f3ec}
.som-resources-head{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s ease;display:flex;align-items:baseline;gap:16px;border-top:1px solid rgba(42,35,32,.14);padding-top:26px;margin-bottom:34px}
.som-resources-head.is-visible{opacity:1;transform:translateY(0)}
.som-resources-head h3{margin:0;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:30px;color:#2a2320}
.som-resources-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.som-resource-card{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease,box-shadow .3s ease,border-color .3s ease;text-decoration:none;color:inherit;padding:30px;background:#fffdf9;border:1px solid rgba(42,35,32,.1);border-radius:14px;display:block}
.som-resource-card.is-visible{opacity:1;transform:translateY(0)}
.som-resource-card:hover{transform:translateY(-5px);border-color:rgba(184,136,78,.55);box-shadow:0 20px 38px -22px rgba(42,35,32,.45)}
.som-resource-card .som-tag{margin-bottom:14px}
.som-resource-card .title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:23px;color:#2a2320;margin-bottom:8px}
.som-resource-card p{margin:0;font-weight:300;font-size:15px;line-height:1.55;color:#6b625c}

/* ===== Footer ===== */
.som-footer{background:#241a1e;color:#cfc6bd;padding:64px 52px 36px}
.som-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;max-width:1040px;margin:0 auto;padding-bottom:44px;border-bottom:1px solid rgba(247,243,236,.1)}
.som-footer-logo{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:22px;letter-spacing:.14em;color:#fdf7ee}
.som-footer p{margin:0 0 22px;font-weight:300;font-size:15px;line-height:1.6;color:#a89e94;max-width:300px}
.som-footer-follow{display:flex;align-items:center;gap:11px;margin-bottom:24px}
.som-footer-follow span{font:500 9px 'IBM Plex Mono',monospace;letter-spacing:.28em;color:#d8c39a;text-transform:uppercase}
.som-social{width:34px;height:34px;border-radius:50%;border:1px solid rgba(247,243,236,.22);display:inline-flex;align-items:center;justify-content:center;color:#cfc6bd;text-decoration:none;transition:color .22s ease,border-color .22s ease}
.som-social:hover{color:#e9c893;border-color:rgba(233,200,147,.6)}
.som-btn-green{background:#2e7d4f;color:#fff;padding:12px 24px}
.som-btn-green:hover{transform:translateY(-2px);background:#286b44}
.som-footer-h{font:500 10px 'IBM Plex Mono',monospace;letter-spacing:.26em;color:#d8c39a;text-transform:uppercase;margin-bottom:18px}
.som-footer-contact{font-weight:300;font-size:15px;line-height:2;color:#cfc6bd}
.som-footer-links{display:flex;flex-direction:column;gap:9px;font-weight:300;font-size:15px}
.som-footer-links a{color:#cfc6bd;text-decoration:none}
.som-footer-links a:hover{color:#e9c893}
.som-footer-bottom{max-width:1040px;margin:22px auto 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font:400 12px 'IBM Plex Mono',monospace;color:#7a7066}

@media (max-width:900px){
  .som-nav ul{display:none}
  .som-menu-toggle{display:block}
  .som-obit-grid{grid-template-columns:repeat(2,1fr)}
  .som-dual-cta,.som-facilities-grid{grid-template-columns:1fr}
  .som-footer-grid{grid-template-columns:1fr}
  .som-resources-grid{grid-template-columns:1fr}
}
