/* Browser internal + website pages. Dipisah dari OS shell agar mudah dikembangkan. */
.site-toolbar { background: rgba(248,250,252,.78); }
.browser-nav-actions { display: flex; align-items: center; gap: 6px; }
.nav-action { width: 30px; height: 30px; border: 0; border-radius: 999px; background: rgba(15,23,42,.06); color: rgba(15,23,42,.72); font-size: 18px; line-height: 1; cursor: default; }
.nav-action:hover { background: rgba(35,120,255,.13); }
.site-address { font-family: ui-monospace, SFMono-Regular, Consolas, monospace; }
.site-browser-body { flex: 1; min-height: 0; display: flex; flex-direction: column; background: linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%); overflow: hidden; }
.site-chrome-header { min-height: 64px; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 0 20px; border-bottom: 1px solid rgba(15,23,42,.08); background: rgba(255,255,255,.72); backdrop-filter: blur(18px); }
.site-brand-mini { display: flex; align-items: center; gap: 10px; min-width: 190px; font-weight: 850; color: #0f172a; letter-spacing: -.02em; }
.site-brand-mini img { width: 32px; height: 32px; border-radius: 10px; }
.site-chrome-nav { display: flex; align-items: center; justify-content: flex-end; gap: 6px; flex-wrap: wrap; }
.site-chrome-nav a { color: rgba(15,23,42,.68); text-decoration: none; font-size: 13px; font-weight: 750; padding: 9px 12px; border-radius: 999px; }
.site-chrome-nav a:hover,
.site-chrome-nav a.is-active { color: #0f172a; background: rgba(35,120,255,.13); box-shadow: inset 0 0 0 1px rgba(35,120,255,.08); }
.site-content-frame { flex: 1; min-height: 0; overflow: auto; padding: 26px; scroll-behavior: smooth; }
.site-content-frame:focus { outline: none; }
.site-loading { min-height: 320px; display: grid; place-items: center; color: rgba(15,23,42,.58); font-weight: 750; }
.website-page { max-width: 1120px; margin: 0 auto; display: grid; gap: 22px; color: #0f172a; }
.site-hero-panel { min-height: 360px; padding: clamp(26px, 4vw, 56px); border-radius: 32px; display: grid; align-content: center; gap: 18px; color: white; background: radial-gradient(circle at 16% 14%, rgba(255,255,255,.34), transparent 28%), linear-gradient(135deg, #1462ff, #6746ef 48%, #081a3d); box-shadow: 0 30px 80px rgba(30,64,175,.23); position: relative; overflow: hidden; }
.site-hero-panel::after { content: ""; position: absolute; right: -90px; bottom: -120px; width: 360px; height: 360px; border-radius: 50%; background: rgba(255,255,255,.12); }
.eyebrow, .site-page-head span { color: inherit; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; font-size: 12px; opacity: .88; }
.site-hero-panel h1 { margin: 0; max-width: 780px; font-size: clamp(34px, 5vw, 72px); line-height: .96; letter-spacing: -.07em; position: relative; z-index: 1; }
.site-hero-panel p { margin: 0; max-width: 660px; color: rgba(255,255,255,.82); font-size: 17px; line-height: 1.65; position: relative; z-index: 1; }
.site-hero-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; position: relative; z-index: 1; }
.site-primary-btn, .site-secondary-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0 18px; border-radius: 999px; font-weight: 850; text-decoration: none; border: 0; }
.site-primary-btn { color: white; background: #0f172a; box-shadow: 0 18px 32px rgba(2,6,23,.18); }
.site-secondary-btn { color: #0f172a; background: rgba(255,255,255,.86); }
.site-metric-grid, .service-grid, .portfolio-grid, .pricing-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.site-metric-grid article, .service-grid article, .portfolio-grid article, .pricing-grid article, .contact-panel, .process-list article { border-radius: 26px; background: rgba(255,255,255,.78); box-shadow: inset 0 0 0 1px rgba(15,23,42,.07), 0 16px 44px rgba(15,23,42,.06); padding: 22px; }
.site-metric-grid strong { display: block; font-size: 18px; margin-bottom: 6px; }
.site-metric-grid span, .service-grid p, .portfolio-grid p, .pricing-grid p, .process-list p, .contact-panel p, .site-page-head p { color: rgba(15,23,42,.62); line-height: 1.6; }
.site-page-head { padding: 6px 2px 0; display: grid; gap: 10px; }
.site-page-head span { color: #2563eb; }
.site-page-head h1 { margin: 0; max-width: 760px; font-size: clamp(30px, 4vw, 54px); line-height: 1.02; letter-spacing: -.055em; }
.site-page-head p { margin: 0; max-width: 720px; }
.service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.service-grid h2, .portfolio-grid h2, .pricing-grid h2, .process-list h2, .contact-panel h2 { margin: 8px 0 8px; letter-spacing: -.03em; }
.service-icon { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 16px; background: rgba(35,120,255,.12); }
.portfolio-cover { height: 150px; border-radius: 20px; margin-bottom: 16px; }
.cover-blue { background: linear-gradient(135deg,#2378ff,#7c5cff); }
.cover-green { background: linear-gradient(135deg,#14b8a6,#22c55e); }
.cover-orange { background: linear-gradient(135deg,#f59e0b,#ef4444); }
.pricing-grid article { display: grid; gap: 8px; }
.pricing-grid article span { color: #2563eb; font-weight: 900; }
.pricing-grid article.featured { background: linear-gradient(135deg, rgba(35,120,255,.92), rgba(124,92,255,.92)); color: white; }
.pricing-grid article.featured p, .pricing-grid article.featured span { color: rgba(255,255,255,.84); }
.process-list { display: grid; gap: 14px; }
.process-list article { display: grid; grid-template-columns: 64px 1fr; gap: 14px; align-items: start; }
.process-list article > strong { width: 50px; height: 50px; display: grid; place-items: center; border-radius: 18px; color: white; background: linear-gradient(135deg,#2378ff,#7c5cff); }
.contact-panel { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.contact-panel h2, .contact-panel p { margin: 0 0 8px; }
.mobile-browser { position: absolute; left: 12px; right: 12px; top: 58px; bottom: 86px; z-index: 30; display: none; flex-direction: column; color: #0f172a; overflow: hidden; border-radius: 26px; background: #f8fbff; box-shadow: 0 32px 90px rgba(2,6,23,.48); }
.mobile-browser.is-open { display: flex; animation: mobileBrowserIn .18s ease both; }
.mobile-browser-bar { height: 48px; display: flex; align-items: center; gap: 9px; padding: 0 10px; background: rgba(255,255,255,.88); border-bottom: 1px solid rgba(15,23,42,.08); }
.mobile-browser-bar button { width: 34px; height: 34px; border: 0; border-radius: 999px; background: rgba(15,23,42,.06); font-size: 22px; color: #0f172a; }
.mobile-address { flex: 1; min-width: 0; display: flex; align-items: center; gap: 8px; height: 34px; padding: 0 12px; border-radius: 999px; background: rgba(15,23,42,.05); font-size: 12px; color: rgba(15,23,42,.68); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mobile-site-nav { display: flex; gap: 6px; overflow-x: auto; padding: 9px 10px; border-bottom: 1px solid rgba(15,23,42,.08); background: rgba(255,255,255,.76); }
.mobile-site-nav button { flex: 0 0 auto; border: 0; border-radius: 999px; padding: 8px 11px; color: rgba(15,23,42,.72); background: rgba(15,23,42,.05); font-weight: 800; }
.mobile-site-nav button.is-active { color: white; background: #2378ff; }
.mobile-browser-content { flex: 1; min-height: 0; overflow: auto; padding: 14px; }
.mobile-browser-content .website-page { gap: 14px; }
.mobile-browser-content .site-hero-panel { min-height: 360px; border-radius: 24px; padding: 24px; }
.mobile-browser-content .site-hero-panel h1 { font-size: 36px; }
.mobile-browser-content .site-chrome-header { display: none; }
.mobile-browser-content .site-metric-grid,
.mobile-browser-content .service-grid,
.mobile-browser-content .portfolio-grid,
.mobile-browser-content .pricing-grid { grid-template-columns: 1fr; }
.mobile-browser-content .contact-panel { align-items: stretch; flex-direction: column; }
.mobile-browser-content .process-list article { grid-template-columns: 48px 1fr; }
@keyframes mobileBrowserIn { from { opacity: 0; transform: translateY(18px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
@media (max-width: 980px) {
  .site-chrome-header { align-items: flex-start; flex-direction: column; padding: 14px; }
  .site-chrome-nav { justify-content: flex-start; }
  .site-content-frame { padding: 16px; }
  .site-metric-grid, .service-grid, .portfolio-grid, .pricing-grid { grid-template-columns: 1fr; }
  .contact-panel { align-items: stretch; flex-direction: column; }
}


/* Step 28 mobile browser fullscreen override */
@media (max-width: 820px) {
  .mobile-browser.mobile-app,
  .mobile-browser {
    position: absolute;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    z-index: 40;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #f8fbff;
    color: #0f172a;
    display: flex;
    flex-direction: column;
    opacity: 0;
    pointer-events: none;
    transform: translateY(24px) scale(.985);
    transition: transform .22s cubic-bezier(.2,.8,.2,1), opacity .22s ease;
  }
  .mobile-browser.is-open { display: flex; opacity: 1; pointer-events: auto; transform: translateY(0) scale(1); animation: none; }
  .mobile-browser-bar { min-height: calc(64px + env(safe-area-inset-top)); height: auto; padding: calc(12px + env(safe-area-inset-top)) 12px 10px; display: grid; grid-template-columns: 38px 96px 1fr; gap: 8px; background: rgba(255,255,255,.92); backdrop-filter: blur(22px) saturate(150%); }
  .mobile-browser-bar button { width: 38px; height: 38px; border-radius: 14px; }
  .mobile-browser-content { flex: 1; min-height: 0; overflow: auto; padding: 12px; }
}

/* Step 41 - Browser pop-out button */
.browser-popout-button { white-space: nowrap; font-weight: 850; }
@media (max-width: 900px) {
  .browser-popout-button { padding-inline: 10px; font-size: 11px; }
}
