/* =========================================================
   In Memory of Caroline Navon Gross — shared stylesheet
   Used by index.php (main page) and guestbook.php (messages)
   ========================================================= */

:root{
  --bg:        #faf8f4;
  --bg-soft:   #f3efe7;
  --ink:       #3c3a35;
  --ink-soft:  #6f6a61;
  --heading:   #2c2a26;
  --accent:    #8a7a5c;
  --line:      #ddd6c8;
  --white:     #ffffff;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Mulish', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight:300;
  line-height:1.8;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3{
  font-family:'Cormorant Garamond', Georgia, serif;
  font-weight:500;
  color:var(--heading);
  line-height:1.2;
}
a{ color:var(--accent); }

img{ max-width:100%; }

.wrap{ max-width:920px; margin:0 auto; padding:0 28px; }

/* ---------- Language switcher (top corner) ---------- */
.lang-switch{
  position:absolute;
  top:20px; right:24px;
  display:flex;
  gap:9px;
  z-index:20;
}
.lang-opt{
  display:block;
  width:30px; height:21px;
  border-radius:3px;
  overflow:hidden;
  box-shadow:0 1px 4px rgba(0,0,0,0.22);
  border:1px solid rgba(0,0,0,0.12);
  opacity:0.45;
  transition:opacity .2s ease, transform .2s ease;
}
.lang-opt:hover{ opacity:0.85; transform:translateY(-1px); }
.lang-opt.active{ opacity:1; outline:2px solid var(--accent); outline-offset:2px; }
.lang-opt svg{ display:block; width:100%; height:100%; }

/* ---------- Two-tab navigation (Tribute / Memories) ---------- */
.site-nav{
  text-align:center;
  padding:26px 28px 4px;
  font-family:'Mulish',sans-serif;
}
.site-nav-link{
  display:inline-block;
  font-size:13px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  text-decoration:none;
  color:var(--ink-soft);
  padding:6px 14px;
  transition:color .2s ease;
}
.site-nav-link:hover{ color:var(--accent); }
.site-nav-link.active{
  color:var(--heading);
  border-bottom:1px solid var(--accent);
  padding-bottom:5px;
}
.site-nav-sep{ color:var(--line); }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  text-align:center;
  padding:60px 28px 70px;
}
.portrait{
  width:190px; height:190px;
  object-fit:cover;
  border-radius:50%;
  margin:0 auto 36px;
  display:block;
  box-shadow:0 10px 35px rgba(0,0,0,0.14);
}
.eyebrow{
  font-family:'Mulish',sans-serif;
  font-weight:400;
  letter-spacing:0.32em;
  text-transform:uppercase;
  font-size:12px;
  color:var(--accent);
  margin-bottom:22px;
}
.hero h1{
  font-size:clamp(2.7rem, 6vw, 4.6rem);
  letter-spacing:0.01em;
}
.hero h1 a{ color:inherit; text-decoration:none; }
.dates{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.5rem;
  color:var(--ink-soft);
  margin-top:14px;
}
.rule{
  width:54px; height:1px;
  background:var(--accent);
  border:0;
  margin:34px auto;
}

/* ---------- Sections ---------- */
section{ padding:54px 0; }
.section-title{ text-align:center; font-size:2.3rem; margin-bottom:8px; }
.section-intro{
  text-align:center;
  color:var(--ink-soft);
  font-style:italic;
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem;
  margin-bottom:38px;
}

/* ---------- Tribute ---------- */
.tribute p{ margin:0 auto 22px; max-width:680px; }
.tribute p:first-of-type::first-letter{
  font-family:'Cormorant Garamond',serif;
  font-size:3.6rem;
  line-height:0.8;
  float:left;
  margin:8px 12px 0 0;
  color:var(--accent);
}
.tribute em{ font-style:italic; }

/* ---------- Gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gallery figure{
  margin:0; overflow:hidden;
  background:var(--bg-soft);
  aspect-ratio:1/1; cursor:pointer;
}
.gallery img{
  width:100%; height:100%;
  object-fit:cover; display:block;
  transition:transform .6s ease;
}
.gallery figure:hover img{ transform:scale(1.05); }

/* ---------- Memories call-to-action (on main page) ---------- */
.mem-cta{ background:var(--bg-soft); }
.mem-cta .wrap{ text-align:center; }

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0;
  background:rgba(28,26,22,0.92);
  display:none; align-items:center; justify-content:center;
  z-index:50; padding:30px; cursor:zoom-out;
}
.lightbox.open{ display:flex; }
.lightbox img{ max-width:100%; max-height:100%; box-shadow:0 20px 60px rgba(0,0,0,0.5); }
.lightbox .lb-close{
  position:absolute; top:22px; right:30px;
  color:#fff; font-size:34px;
  font-family:'Cormorant Garamond',serif;
  cursor:pointer; line-height:1;
}
.lightbox .lb-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  color:#fff; font-size:46px;
  font-family:'Cormorant Garamond',serif;
  cursor:pointer; user-select:none; padding:10px 20px; opacity:0.75;
}
.lightbox .lb-nav:hover{ opacity:1; }
.lightbox .lb-prev{ left:6px; }
.lightbox .lb-next{ right:6px; }

/* ---------- Guestbook ---------- */
.guestbook{ background:var(--bg-soft); }
.messages{ max-width:680px; margin:0 auto 40px; }
.message{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:8px;
  padding:24px 26px; margin-bottom:16px;
}
.message .m-text{ white-space:pre-wrap; word-wrap:break-word; overflow-wrap:break-word; }
.message .m-meta{
  margin-top:14px; font-size:14px;
  color:var(--accent);
  font-family:'Mulish',sans-serif;
  letter-spacing:0.04em;
}
.message .m-name{ font-weight:600; }
.no-messages{
  text-align:center; color:var(--ink-soft);
  font-style:italic;
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem; margin-bottom:38px;
}

/* ---------- Form ---------- */
form.gb-form{
  max-width:560px; margin:0 auto;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:8px;
  padding:34px 32px;
}
form.gb-form label{
  display:block; font-size:13px;
  letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:8px;
}
form.gb-form input[type=text],
form.gb-form textarea{
  width:100%;
  font-family:'Mulish',sans-serif;
  font-size:16px; font-weight:300;
  color:var(--ink);
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:6px;
  padding:12px 14px; margin-bottom:22px;
}
form.gb-form textarea{ min-height:130px; resize:vertical; }
form.gb-form input:focus, form.gb-form textarea:focus{
  outline:none; border-color:var(--accent);
}
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

.btn{
  display:inline-block;
  font-family:'Mulish',sans-serif;
  font-size:13px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:#fff; background:var(--accent);
  border:0; border-radius:6px;
  padding:14px 34px; cursor:pointer;
  text-decoration:none;
  transition:background .25s ease;
}
.btn:hover{ background:#73654a; }

.notice{
  max-width:560px; margin:0 auto 26px;
  padding:14px 20px; border-radius:6px;
  text-align:center; font-size:16px;
}
.notice-ok{ background:#eef1e7; border:1px solid #c9d3b3; color:#5a6638; }
.notice-err{ background:#f6e9e6; border:1px solid #e0c3bc; color:#8a4f43; }
.notice-err ul{ list-style:none; }

.back-link{
  text-align:center;
  margin-top:36px;
  font-family:'Mulish',sans-serif;
  font-size:14px;
  letter-spacing:0.04em;
}

/* ---------- Footer ---------- */
footer{
  text-align:center;
  padding:46px 28px 60px;
  color:var(--ink-soft);
  font-size:14px;
}
footer .rule{ margin:0 auto 26px; }

/* ---------- Right-to-left (Hebrew) ---------- */
[dir="rtl"] body,
body[dir="rtl"]{ font-family:'Heebo', -apple-system, sans-serif; }
[dir="rtl"] h1,
[dir="rtl"] h2,
[dir="rtl"] h3{ font-family:'Frank Ruhl Libre','Cormorant Garamond',serif; }
[dir="rtl"] .lang-switch{ right:auto; left:24px; }
[dir="rtl"] .tribute p:first-of-type::first-letter{
  float:right; margin:8px 0 0 12px;
}
[dir="rtl"] .eyebrow{ letter-spacing:0.12em; }
[dir="rtl"] .dates,
[dir="rtl"] .section-intro,
[dir="rtl"] .no-messages{ font-style:normal; font-family:'Frank Ruhl Libre',serif; }
[dir="rtl"] form.gb-form label{ text-transform:none; letter-spacing:0.02em; font-size:14px; }
[dir="rtl"] .btn{ text-transform:none; letter-spacing:0.03em; font-size:15px; }
[dir="rtl"] .site-nav-link{ text-transform:none; letter-spacing:0.04em; font-size:15px; }
[dir="rtl"] .message .m-meta{ letter-spacing:0; }
[dir="rtl"] .lightbox .lb-close{ right:auto; left:30px; }
[dir="rtl"] .lightbox .lb-prev{ left:auto; right:6px; }
[dir="rtl"] .lightbox .lb-next{ right:auto; left:6px; }

/* ---------- Tablet ---------- */
@media (max-width:820px){
  .wrap{ padding:0 24px; }
  .hero h1{ font-size:clamp(2.4rem, 7vw, 3.6rem); }
}

/* ---------- Phone ---------- */
@media (max-width:600px){
  body{ font-size:17px; line-height:1.75; }
  .wrap{ padding:0 20px; }

  /* the flags and the tabs stack neatly at the very top, centered */
  .lang-switch{
    position:static;
    justify-content:center;
    padding:18px 0 0;
  }
  [dir="rtl"] .lang-switch{ left:auto; right:auto; }
  .lang-opt{ width:34px; height:24px; }
  .site-nav{ padding:14px 18px 0; }
  .site-nav-link{ font-size:12px; letter-spacing:0.13em; padding:6px 9px; }
  [dir="rtl"] .site-nav-link{ font-size:14px; letter-spacing:0.03em; }

  .hero{ padding:22px 20px 44px; }
  .portrait{ width:148px; height:148px; margin-bottom:24px; }
  .eyebrow{ font-size:11px; letter-spacing:0.2em; margin-bottom:16px; }
  .hero h1{ font-size:2.15rem; }
  .dates{ font-size:1.2rem; margin-top:10px; }
  .rule{ margin:26px auto; }

  section{ padding:38px 0; }
  .section-title{ font-size:1.85rem; }
  .section-intro{ font-size:1.12rem; margin-bottom:28px; }

  .tribute p{ margin-bottom:18px; }
  .tribute p:first-of-type::first-letter{ font-size:2.9rem; margin:6px 9px 0 0; }
  [dir="rtl"] .tribute p:first-of-type::first-letter{ margin:6px 0 0 9px; }

  .gallery{ grid-template-columns:repeat(2,1fr); gap:9px; }

  .message{ padding:20px 20px; }
  form.gb-form{ padding:26px 20px; }
  .btn{ padding:14px 26px; }

  .lightbox{ padding:12px; cursor:auto; }
  .lightbox .lb-close{ top:12px; right:16px; font-size:38px; }
  [dir="rtl"] .lightbox .lb-close{ right:auto; left:16px; }
  .lightbox .lb-nav{ font-size:30px; padding:4px 8px; }

  footer{ padding:38px 22px 52px; }
}

/* ---------- Small phone ---------- */
@media (max-width:380px){
  .hero h1{ font-size:1.9rem; }
  .gallery{ gap:7px; }
  .site-nav-link{ letter-spacing:0.1em; padding:6px 7px; }
}
